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WARNING — It has been determined that reading this ad may be hazardous to your health, if you own 
another type computer system. We will not be responsible for ulcers, heartburn, or other 
complications if you persist in reading this material. 


4 K BASIC — 8KBASIC 


Full floating point math 

1.0E-99 to 9.99999999E+99 number range 

User programs may be saved and loaded 

Direct mode provided for most statements 

Will run most programs in 8K bytes of memory (4K Version) 
or 12K bytes of memory (8K Version) 

USER function provided to call machine language programs 

String variables and trig functions-8K BASIC only 


COMMANDS 
LIST 
RUN 
NEW 
SAVE 
LOAD 
PATCH 


STATEMENTS 
END 

GOTO* 

ON. ..GOTO* 
ОМ. ..GOSUB" 
IF. ..THEN* 
INPUT 
PRINT* 
NEXT 


FUNCTIONS 

t VAL 

t EXTS 

t LENS 
SGN t LEFT$ 
CHR f MID$ 
USER t RIGHTS 
TAB 


REM 

DIM 
DATA 
READ 
RESTORE 
LET* 

FOR 


ABS 
INT 
RND 


STOP 
GOSUB* 
PATCH* 
RETURN 


t DES 
t PEEK 
t POKE 


* Direct mode statements 


7 &K Version only 


MATH OPERATORS 
- (unary) Negate 

* Multiplication 

/ Division 

+ Addition 
Subtraction 
Exponent 


t 4 


© Copyright 1976 by Southwest Technical Products 


RELATIONAL OPERATORS 
Equal 
Not Equal 
Less Than 
Greater Than 
Less Than or Equal 
Greater Than or Equal 


Corp. 4K and 8K BASIC Version 1. 


BANKAMERICARD 


iwelbome few 


WE HONOR 


master charge 


THE INTERBANK CARD 


0 program material 


and manual! may be copied for personal use only. No duplication or modification for commercial use of any 


kind is authorized. 


You guys are out of your minds, but who am I to complain. Send — 


4K BASIC CASSETTE $4.95 
8K BASIC CASSETTE $9.95 
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C) MP-68 Computer 
Kit $395.00 
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Southwest Technical Products Corp. 
Box 32040, San Antonio, Texas 78284 


You get more games, 
more fun, more computer uses 
with this new ioystick 


AND THERE'S AN 
EASY WAY TO INPUT IT 
TO YOUR COMPUTER 

You'll get a lot more fun out of 
your computer with this new joy- 
stick. 

But note that it is not just an 
ordinary joystick — it is a console. It 
has a 2-axis joystick and contains a 
speaker and speaker amplifier. You 
can have sound with your games or, 
say, warning sounds in 


dE s other applications. Or 
have your computer 

talk to you. 
A third feature you 
Four get is four pushbutton 
pushbuttons switches. These give 


you even more pos- 
[1] sible uses such as se- 
[2] lecting various colors 
[3] on a color graphics 
[4] terminal. 


EASY TO COUPLE 
To couple the new joystick to 
your computer, just use our D+7A™ 
1/O board. it will couple not only 
one but two consoles to your Altair™ 


8080 
| COMPUTER | 


Plugs 
into 
computer 


CROMEMCO 
JOYSTICK 


8800 or IMSAI 8080. And you'll still 
have several analog channels left 
over (and one 8-bit output port). 

The D+7A plugs into the Stand- 
ard 100 (S-100) bus of your Altair or 
IMSAI computer. 


EASY TO DISPLAY 
Displaying the joystick outputs 
with the software below is also easy. 
Just use our TV DAZZLER™ board. 
It also plugs into the S-100 bus. 


NEW SOFTWARE 

Here's some new Cromemco soft- 
ware for the joystick (to display, use 
DAZZLER interface): 

CHASE! (2 persons, 2 joysticks): 
the cross chases the circle. The ver- 
tical bars move downward to add 
more fun to the chase. Score and 
remaining time kept automatically. 

TRACK (1 person, 1 joystick): 
move the dot to the center of the 
spiral without touching the spiral's 
arms. 

DAZZLE DOODLE (1 person, 1 
joystick): lets you draw pictures in 
4 colors on your color TV terminal 
using the joystick. 


CROMEMCO 
D+7A 1/0 


CROMEMCO 
TV 
DAZZLER 


into 
computer 


STORE/MAIL 
Cromemco wishes you more fun, 
more use from your computer. Get 
this new joystick console and other 
Cromemco peripherals at your com- 
puter store or order from the factory. 


Joystick console kit 


(Model ISIK ЖЫ >... % 65 
Joystick console assembled 
(Model JS-1W) ............... $ 95 


D+7A I/O kit (Model D+7A-K) ..$145 
D+7A I/O assembled 

(Model D+7A-W) ............ $245 
TV DAZZLER kit (Model CGI-K) ...$215 
TV DAZZLER assembled 

(Model CGI-W) ............... $350 


SOFTWARE 
(Punched paper tape 
with documentation) 


АА оо ООО ОА Я $15 
TRACK БАУ. У 636 $15 
DAZZCESSISODLE ТАТ 202722. $15 


PROMPT SHIPMENT 


Mastercharge and BankAmericard accepted with 
signed order. Please show complete card number 
and expiration date. 
Mail orders shipped prepaid if fully paid with 
order. Purchase orders accepted subject to credit 
approval. 

California users add 6% sales tax. 


Cromemco 


Specialists in computers and peripherals 


2432 CHARLESTON RD., MOUNTAIN VIEW, CA 94043 * (415) 964-7400 
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It’s More Fun Than Crayons! Read 
how Mike and Alex Rosner, ages 7 and 
5, discovered the joys of computer art 
and incidentally proved the need for 
timesharing computers in the home. 
On the cover are super stars Mike and 
Alex at work. 


If Isaac Newton were alive today, 
he’d be immersed in long and com- 
plicated physics manipulations, which 
are ultimately tested using calculations 
involving multidimensional matrices 
and matrix operations of linear alge- 
bra. Chances are he might be inter- 
acting with a computer, with an inter- 
preter from the APL tree of languages. 
Read Mark Arnold’s What Is APL? to 
find out a bit about APL, a language 


page 106 


page 78 


with a mathematical orientation but 
utility for general purpose program- 
ming as well. 


How do you do graphics in a 
weekend, without spending a fortune? 
In Beer Budget Graphics, Peter Nelson 
tells all: how the synergistic combina- 
tion of a couple of digital to analog 
converters and an output latch or two 
brings the world of point plotting to 
an oscilloscope for about $20 in parts. 


In the July 1976 BYTE, we rana 
functional specification for a graphics 
interface in answer to reader Paul 
Hyde Jr’s letter. Practically before the 
ink had dried on the July press run 
(figure of speech) reader Thomas R 
Buschbach sent in this article on how 
he made just such a graphics interface 
for his Digital Group system using 
existing timing logic of the television 
display unit. Given an existing 8 К 
memory, processor and television dis- 
play generator, this high resolution 
display can be added to a system for as 
little as $25 in additional semicon- 
ductors. 


page 32 


Star Trek freaks should turn to Joe 
Deres’ article to find An Enterprising 
Display. In the article you'll find 
information on a design for a tele- 
vision graphics output which can be 
built from a kit (ог your own parts) 
for less than $100. 


Ira Rampil provides Some Graphics 
Background Information, including a 
comparison of several display devices 
available to individuals. 


Don't be satisfied with simple visual 
readouts. Make Your Next Peripheral a 
Real Eye Opener by implementing a 
true vector display using an XY oscil- 
loscope, circuits and software similar 
to Steve Ciarcia’s design. In his article 
you'll see how to draw a picture of a 
moderately high resolution Star Ship 
Enterprise. 


Build This Video Display Terminal, 
advises Alfred Anderson, who took 
CW Gantt Jr's TV interface circuit 
described in the June 1976 BYTE, 
made a few changes, added a few 
goodies, and wrote a few lines of 
software, Now he tells you how you 
can do it. 


What's NOT In This BYTE 


... Software Bug of the Month, Book 
Reviews, Ask BYTE, a slew of What's 
New and BYTE's Bits items we were 
dying to print, lots of good letters, and 
some dynamite articles, Even using 
smaller type in places didn't enable us 
to include much that we urgently 
wished to. If you missed it this month, 
watch for it next. 
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BUILD THE BEER BUDGET GRAPHICS INTERFACE 


Graphics System—Nelson 


ADD THIS GRAPHICS DISPLAY TO YOUR SYSTEM 


Hardware—Buschbach 


AN ENTERPRISING DISPLAY DEVICE 


Hardware—Deres 


MAKE YOUR NEXT PERIPHERAL A REAL EYE OPENER 


Graphics Systems—Ciarcia 


BUILD THIS VIDEO DISPLAY TERMINAL 


Systems—Anderson 
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A Proposed Standard for Publishing 
Binary Data in Machine Readable Form 
The Address Space Saturation Problem 
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Kil O'Byte 


What's New? 
Description: MERLIN Video Interface 
Something for Everyone 
Letters 

BYTE's Bugs 

Clubs, Newsletters 
Classified Ads 

BYTE's Bits 
Description: Astral 2000 
BOMB 

Reader's Service 


BYTE magazine is published 
monthly by BYTE Publica- 
tions Ine, 70 Main St, Peter- 
borough New Hampshire 
03458. Subscription rates are 
$12 for one year, $22 for two 
years, $30 for three years in 
North America, Elsewhere: 
$15 one year, $25 two years, 
$33 three years, Second class 
postage paid at Peterborough 
NH 03458 and at additional 
mailing offices, Phone 
603—924-7217. Entire con- 
tents copyright 1976 BYTE 
Publications Inc, Peterborough 
NH 08458, Address editorial 
correspondence to Editor, 
BYTE, 70 Main St, Peter- 
borough NH 034658. 
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Imagine a microcomputer 


Imagine a microcomputer with all the design 
savvy, ruggedness, and sophistication of the best 
minicomputers. 


Imagine a microcomputer supported by dozens 
of interface, memory, and processor option boards. 
One that can be interfaced to an indefinite number 
of peripheral devices including dual floppy discs, 
CRT's, line printers, cassette recorders, video dis- 
plays, paper tape readers, teleprinters, plotters, 
and custom devices. 


Imagine a microcomputer supported by exten- 
sive software including Extended BASIC, Disk 
BASIC, DOS and a complete library of business, 
developmental, and industrial programs. 


Imagine a microcomputer that will do everything 
a mini will do, only at a fraction of the cost. 

You are imagining the Altair '" 8800b. The Altair 
8800b is here today, and it may very well be the 
mainframe of the 70's. 


The Altair 88006 is a second generation design 
of the most popular microcomputer in the field, 
the Altair 8800. Built around the 8080A micro- 
processor, the Altair 8800b is an open ended 
machine that is compatible with all Altair 8800 
hardware and software. It can be configured to 
match most any system need. 


NOTE: Altair is a trademark of MITS, Inc. 
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Redesigned front panel. Totally synchro- 
nous logic design. Same switch and LED 
arrangement as original Altair 8800. 
New back-lit Duralith (laminated plastic 
and mylar, bonded to aluminum) dress 
panel with multi-color graphics. New 
longer, flat toggle switches. Five new 
functions stored on front panel PROM 
including: DISPLAY ACCUMULATOR (dis- 
plays contents of accumulator), LOAD 
ACCUMULATOR (loads contents of the 
8 data switches (A7-AO) into accumulator) 
OUTPUT ACCUMULATOR (Outputs con- 
tents of accumulator to I/O device 
addressed by the upper 8 address 
switches), INPUT ACCUMULATOR (in- 
puts to the accumulator from. the 1/О 
device), and SLOW (causes program 
execution at a rate of about 5 cycles per 
second —for program debugging). 


New, heavy duty power supply +8 volts 
at 18 amps, + 18 volts at 2 amps, 18 volts 
at 2 amps. 110 volt or 220 volt operation 
(50/60 Hz). Primary tapped for either 
high or low line operation. 


Full 18 slot motherboard. 


Rugged, commercial grade Optima 
cabinet. 


New front panel interface board buffers 


all lines to and from 8800b bus. New CPU board with 8080A micro- 


processor and Inte! 8224 clock generator 
and 8216 bus drivers. Clock pulse widths 
and phasing as well as frequency are 
crystal controlled. Compatible with all 
current Altair 8800 software and 
hardware. 


altair 8800-b 


Two, 34 conductor ribbon cable assem- 
blies. Connects front panel board to front 
panel interface board. Eliminates need 
for complicated front panel/bus wiring. 


MITS, Inc. 1976/2450 Alamo S.E./ Albuquerque, New Mexico 87106 


Photo 1: Alex Rosner, age 
5, shown preparing the 
graph paper coding sheet 
for his picture from a pen- 
cil sketch. Once the cor- 
relation between picture 
locations and commands 
was learned, both children 
stopped planning layouts 
in advance on the coding 
sheets. The “snow with 
house and mailbox” is 
shown in photo 5. 


Richard Rosner 
Pocono Rd 
Brookfield CT 06804 


Photo 3: "Cage," by Alex 
Rosner, freehand. 


It’s More Fun 


Now that the home computer is emerging 
from its crystal radio stage and now that we 
are becoming more applications oriented 
rather than hardware oriented, we are going 
to find that we have competition for com- 
puter time right in our homes. While | have 
been putting microcomputers using micro- 
processors together for almost two years, it 
wasn't until | hooked up the TV to my 
present system that my family took interest. 


With Moon, 
Rosner. 
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Photo 4: Rocket Ship 
by Mike 


Now, when | walk in the door after work, 
the kids corner me asking which one can use 
the computer first. 

The microcomputer system uses a MOS 
Technology 6502 CPU, a TIM (Teletype 
Interface Monitor), and 1 kilobyte of pro- 
grammable memory. The graphics module 
contains a 2 K by 8 programmable memory 
allowing a 128 by 128 point display. In 
these pictures the display is configured 


Photo 5: Snow With 
House and Mailbox, by 
Alex Rosner. 


Than Crayons 


(under software control) as a 32 by 32 array. 
The data for the display is entered seri- 
ally. The software commands are 
R, reset to top line, 
N, go to beginning of next line, 
W, enter a white square, 
K, enter a black square, and 
H, halt (return to monitor). 
The procedure is to take a piece of graph 
paper with a 32 by 32 grid blocked off and 


Photo 6: Rocket Ship, by 
Mike Rosner. 


Photo 7: Fun Play (Swing 
Set, Man, Sun and Mail 


to then draw a picture by filling in some of 
the squares. After the drawing is complete 
the paper tape with the program is loaded 
into the processor and the data is entered 
with the above five commands using the 
drawing as a coding sheet. 

This, of course, is not an ideal hardware 
or software approach for a video interface. 
The interface was built for another applica- 
tion and the processor was used as a test 


Photo 2: Michael Rosner, 
age 7, sitting at the Tele- 
type entering data for the 
image of a rocket ship 
with moon (see also photo 
4). 


Box), by Alex Rosner. 
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Photo 8: Flower Puzzle, 
by Mike Rosner, freehand, 


If you thought a rugged, 
professional yet affordable 
computer didnt exist, 


think 
IMSAI 
8080. 


Sure there are other commercial, 
high-quality computers that can 
perform like the 8080. But their 
prices are 5 times as high. There is 
a rugged, reliable, industrial com- 
puter, with high commercial-type 
performance. The IMSAI 8080. 
Fully assembled, it's $931. 
Unassembled, it's $599. And ours 
is available now. 

In our case, you can tell 
a computer by its cabinet. The 
IMSAI 8080 is made for commer- 
cial users. And it looks it. Inside 
and out! The cabinet is attractive, 
heavy-gauge aluminum. The 
heavy-duty lucite front panel has 
an extra 8 program controlled 
ЕР». It plugs directly into the 
Mother Board without a wire 
harness. And rugged commercial 
grade paddle switches that are 
backed up by reliable debouncing 
circuits. But higher aesthetics on 
the outside is only the beginning. 
The guts of the IMSAI 8080 is 
where its true beauty lies. 

The 8080 is optionally 
expandable to a substantial system 
with 22 card slots in a single 
printed circuit board. And the 
durable card cage is made of 
commercial-grade anodized 


aluminum. 
The IMSAI 8080 power 


supply produces a true 28 amp 
current, enough to power a full 
system. 

You can expand to a 
powerful system with 64K of 
memory, plus a floppy disk con- 
troller, with its own on-board 
8080-апа a DOS. A floppy disk 
drive, an audio tape cassette input 
device, a printer, plus a video 
terminal and a teleprinter. These 
peripherals will function with an 
8-level priority interrupt system. 
IMSAI BASIC software is avail- 
able in 4K, that you can get in 
PROM. And a new $139 4K 
RAM board with software 


ІМЅАІ 8080 


memory protect. For the ultimate 
in flexibility, you can design the 
system for low-cost multiprocessor, 
shared memory capability. 

Find out more about the 
computer you thought didn’t 
exist. Get a complete illustrated 
brochure describing the IMSAI 
8080, options, peripherals, soft- 
ware, prices and specifications. 
Send one dollar to cover handling. 

Call us for the name of the 
IMSAI dealer nearest you. 

Dealer inquiries invited. 


IMSAI 


IMS Associates, Inc. 
14860 Wicks Boulevard 
San Leandro, CA 94577 
(415) 483-2093 


Dept. B-11 
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Photo 9: House, by Alex 
Rosner. 
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Photo 10: Шиѕіоп Num- 
ber 4, by Mike Rosner, 
freehand. 


Photo 11: Tree Record, by 
Alex Rosner, freehand. 
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fixture. After testing the display unit, | put а 
little “HELLO МОМ” and a starship on the 
screen and showed it to my wife and two 
kids. The children immediately wanted to do 
the same thing and we now have a new toy. 

The older child, Michael, is seven and 
learned to generate a picture and use the 
program after about’ two hours of instruc- 
tion. He is shown in photo 2 as he puts his 
third creation on the screen, a rocket with 
the moon. Above his right hand can be seen 
the drawing he is working from. (The pat- 
tern in the lower portion of the TV screen is 
the random data in the programmable 
memory chips when the power is turned on.) 
All his efforts at keypunching have been 
saved on paper tape for delayed replay when 
Grandma comes to visit. 

The younger child, Alex, five, is shown in 
photo 1 as he prepares the coding sheet from 
a sketch for his third picture — a house with 
mailbox and snow. Alex required a consider- 
able amount of help with his first two 
pictures, but he quickly learned to use the 
graph paper correctly. 

The cover photo shows the entire setup. 
Alex is putting a picture on the TV while 
Mike is using BRUIN (a language similar to 
BASIC). It seems that second graders are 
now being taught the rudiments of algebra. 
When my calculator batteries went dead | 
called up my company's computer to do 
some simple calculations. Mike saw me using 
the CRT terminal and wanted to try it. 
While we can't call this programming, he is 
having fun. 

The collection of photos from the TV 
screen shows some of the work the kids have 
been doing along with the titles. The incep- 
tion, generation and titling of all the pictures 
are the kids’ own without help from adults. 
Mike's first three pictures were made using 
work sheets as were Alex's first three. The 
rest were made without first making 
drawings. 

The microcomputer is set up in the family 
playroom. | consider myself quite fortunate 
in that | have never had to fight with my 
wife for space. From the beginning of this 
venture | have had my wife's full support. 
Perhaps this is because (as she has recently 
informed me) she plans on using the com- 
puter to help her in the various business 
courses in which she is enrolling, as well as 
for household functions such as diet menu 
planning. 

If you are as lucky as | am, you may find 
yourself putting up a signup sheet as the 
family competes for computer time. 


Photo 12: Mike's first 


work, no title. 
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Photo 13: “Black Cat” by 
Alex Rosner, freehand. 


Photo 14; “Illusion Num- 


ber 1” by Mike Rosner, 
freehand. 


Editor’s Note: Readers 
will detect а careful 
balance between the 
amount of photographic 
exposure given to Alex 


and Mike. Author Richard 
Rosner reports that the 
realpolitik of family life 
requires equal treatment 
for both children in his 
article. . . CH 


Walter Banks and Roger Sanderson of the University of Waterloo, 
Waterloo, Ontario CANADA, have proposed a method of publishing machine 
readable programs in magazines such as BYTE. This proposal was the subect 
of some discussion іп а .technical session at the Personal Computing 76 
show in Atlantic City. | wrote the present report, based upon preliminary 
written information provided by Walter and Roger, and telephone discussions 
with Walter on August 15 1976. The technical content of this report, with 
the exception of the proposal of format 3 and addition of a frame 
identification field to the block format, is supplied by Walter and 
Roger. ... CH 


A Proposed Standard for Publishing 


Binary Data in Machine Readable Form 


by 

Walter Banks 

Computer Communications Network Group 
Roger Sanderson 

Dept of Electrical Engineering 

University of Waterloo 

Waterloo, Ontario CANADA 


and 


Cari Helmers 
Editor, BYTE magazine 


Purpose 


Th 


e purpose of this technology is to 


provide a method of encoding binary data in 
the form of printed marks on a magazine, 


book 


or other published page. These printed 


marks are to be in a predefined format 
which can be read by a simple and inexpen- 
sive optical scanning head which drives a 


single 


bit input port of a personal computer; 


decoding will be done by means of software 
in the computer. The goal is to provide a 
means of disseminating program information 
in a machine readable form. 


Physical Formats 


Figure 1 details three possible physical 
formats. These are proposals at the present 


time. 


Other formats are possible and should 


not be excluded from contention; readers 
are invited to make proposals. The formats 
are described in the captions of figure 1. The 
following comments can be made. 


Format 1, bar width modulation with 
alternate light and dark, is the most 
compact method of encoding. 115 den- 
sity varies with the detailed content, 
but for a given minimum light (or 
dark) interval measurable by the input 
routine and a given binary string of 
data, this method will be higher den- 
sity than either format 2 or format 3 
below. A disadvantage is that emer- 
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gency manual reading of the data with 
a magnifier is probably more difficult 
due to the need to interpret four 
states: wide space, wide mark, narrow 
space, narrow mark. This method had 
been proposed for use in the retail 
trade by Research Inc, Box 24064, 
Minneapolis MN 55424, some time 
ago, before the UPC (Universal Pro- 
duct Code) scheme was adopted for 
grocery product checkout use. 

* Format 2, ratio recording, has an 
advantage in certain points of view in 
its fixed width. Being fixed width, the 
amount of data per page is fixed, as is 
the amount of data per line of ma- 
chine readable type. However, it is a 
lower density form than either format 
1 or format 3 below. It can probably 
be read by eye with greater ease than 
format 1 since every bit is present as a 
short or long bar which is actually 
printed, and only two states need be 
interpreted. 

* Format 3, fixed gap bar width modula- 
tion, is basically a higher density ver- 
sion of ratio recording. Take the lay- 
out of format 2, and compress the 
gaps between black marks to a fixed 
length, and you will get format 3. 
Since this format is higher density, it 
may be preferable to format 2, while 
retaining the advantages of having a 
human readable black mark for every 
bit. 


Frame Layout and Page Layout 


Figure 2 shows the layout of a single 
frame of information, interpreted within the 


Pick a card. Any card. 


From the Digital Group. 


If you've been considering the purchase of a microcompu- 
ter and looking at the myriad of products on the market, 
chances are you're just a bit confused about which system 
makes sense for you. 


As you've no doubt discovered by getting further into this 
fascinating hobby, if there is one constant it is constant 
change. So how do you go about protecting the considerable 
investment you are about to make in a microprocessor? 


The Digital Group offers a safe way to hedge your bets. 
Here's how we do it: 


CPU-Independent Bus Structure 


Digital Group systems are based on an extensive bus struc- 
ture (the equivalent of 200 lines) that allows you to com- 
pletely change your system's architecture by merely ex- 
changing CPU cards and reading in a new operating system 
tape. It's that simple. One card and a tape to get from 6500 
to 6800 to 8080A to the remarkable new Z-80. Or some- 
thing even newer. 


The Digital Group system design is quite complex but the 
result is simple. All CPU dependencies are handled on the 
CPU card — nothing else in the system changes. Not mem- 
ory, readouts, I/O interfaces or even cabinets. And that re- 
presents a significant savings for you. 


When many Digital Group system owners wanted to upgrade 
to the revolutionary new Z-80 CPU, it cost them a total of 
$185. Nothing more. 


Stand-Alone Design 


Each component in a Digital Group system is designed to 
be as independent from the other components as possible. 


Most of our designs are parallel port driven with their own 
buffers. If you can get eight bits to a Digital Group inter- 
face, it'll take over and get the job done. 


Coordinated Cabinets 


Right down to our new line of cabinets, Digital Group sys- 
tems are designed to protect your investment and keep you 
at state of the art. Every one of our unique, custom cabi- 
nets is part of a coordinated line, and you can rest assured 
that each new product will maintain the same unmistakable 
up-to-the-minute Digital Group image. 


As much as is possible in this fast-growing, ever-changing 
field, the Digital Group offers protection from obsolescence. 
So go ahead and pick a card. Any card from the Digital 
Group is a safe bet. 


tne clightal group 


P.O. Box 6528 / Denver, Colorado 80206 / (303) 777-7133 


OK, I'm ready for details on your systems and all the extras. 
Deal me in. 


Name 
Address 
City/State/Zip 


Figure 1: Three possible formats, These are proposals at this time, with the appropriate parameters indicated. 


FORMAT ! 


Figure 1а: Format 1: Bar 
width modulation, with al- 
ternate dark and light. The 
parameters to be specified 
in printing are widths TO 
апа T1. A trailing bit com- 
plementary to the last data 
bit in а string is required. 
The leading bit of a string 
will be assumed to be in 
the dark state. In reading 
this code, time between 
transitions falls into two 
categories, long for a 1 bit, 
and short for a 0 bit. 


4 
| 


4 
@ 
© 


тш 
TB 4 1 
Ен Е 
аини 
Ta d о 
| o 
1 
иш 
о 
ннн 
о 
ннн 
— D 


Figure 1b: Format 2: Ratio recording. The 
parameters to be specified in printing are the 
bit length, TB and the TO and T1 widths for 
states of the data. This format has a fixed 
length per bit which is independent of the 
state of the data. In reading this code, the 
time from one light to dark transition to the 
next light to dark transition is the duration 
of the bit cell, which is compared to the 
duration of the dark period to find out 
whether a 1 bit (long) or 0 bit (short) was 
read. 


string as a synchronization pattern followed 
by 8 bit bytes of information. 


The SYNCH pattern is an 8 bit character 


which must occur as the first byte of every 
frame, and may be preceded by several 
timing bits to initialize adaptive software. 
Once the input string equals the SYNCH 


TIMING BITS 


SYNCH CHECKSUM | FRAMEID | LENGTH n | DATA О DATA 2 B 


Figure 1с: Format 3: Fixed gap bar width 
modulation. The parameters to be specified 
in printing are the interbar gap width TG, 
and the bit length parameters TO and ТІ. In 
reading this code, the length of the interbit 
gap gives a calibration for judging the next 
dark period as a 0 bit (short) or 1 bit (long). 
The data density (as in format 1) varies with 
the statistics of the number of Os and 15 ina 
given region of the printed data. 


character, the decoding algorithm can pro- 
ceed bit by bit with the rest of the frame. 
The CHECKSUM field contains an 8 bit 
check sum of the data in the current frame. 
This is the primary error detection technique 
employed. In manual scanning, when an 
error occurs, the sensor head can be drawn 


\ | DATA n-i DATA п 


Figure 2: Frame Format, The timing bits may not be required, but provide a preliminary leader 
before the ASCII SYN character (hexadecimal 16) which leads off the frame. All data is 
transmitted most significant bit first. Following the synchronization character is an 8 bit check 
sum representing 2% complement modulo 256 summation of all the remaining data on the 
record. The FRAMEID field is an 8 bit integer used for relative positioning within an extended 
file. Its purpose is to allow manual rescan in the event of errors, so that the software will 
recognize the input as the same record. The length field contains a direct integer value for the 
number of bytes in the data field. From 1 to 255 bytes can be in the data field; a length of 0 is 
reserved for a special case "end of file" frame. Finally, the remainder of the frame contains 8 


bit bytes of data. 
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We've got it! 
£-80 power for 
the Altair bus. 


Неге itis, TDL's ZPU™ the high- 
est point of technology for an 
Altair/IMSAI system. Now, you 
can multiply your present cap- 
abilities without creating cost- 
ly obsolescence. Take advan- 
tage of the wide range of exist- 
ing hardware backup for your 
current system. The ZPU is 
compatible and dependable 
with many plus features you'll 
want to know about. 

To further round out your 
system we also have available 
the fastest and lowest power 
static ram boards going (from 
4 to 16K with expansion) and 
a system monitor board with 
а 2-80 monitor, powerful I/O 
and audio casette features. 

As for software, TDL's user 
support program is unmatched 
in the micro-processor indus- 
try, currently available are the 
2-80 monitor, basic, and the 
most sophisticated MACRO- 
ASSEMBLER yet developed. 

Join the Z-80 revolution — 
it’s more than just hardware! 


ZPU Kit $269.00 
Z16K Kit $574.00 


HOW TO ORDER Just send check or 
money order, or use your BankAmericard 
or Mastercharge, and your orders will be 
shipped to you postpaid. COD orders must 
be accompanied by a 25% deposit. Your 
credit card order must include the serial 
# of the card, expiration date, and your 
order must be signed. New Jersey resi- 
dents add 596 state sales tax. For more 
information, send for our free catalog. 


Dealer Inquiries Invited. 


TECHNICAL DESIGN LABS, INC. 
342 COLUMBUS AVENUE 
TRENTON, NEW JERSEY 08629 


(609) 392-7070 


Figure 3: Page Layout. А 
page of data in printed 
form [as we would run in 
BYTE] would be laid out 
with the data running par- 
allel to the center margin 
of the magazine. This al- 
lows the maximum 
amount of data in a frame, 
thus minimizing the over- 
head bits of the frame 
format. 


A low density test string. 


CENTER MARGIN OF MAGAZINE PAGE 


FRAME N START SCAN 


r 
FRAME №+1 V 
^ 
FRAME N+2 M 
r 
FRAME N+3 bd 
r 
FRAME N+4 M 
r 
FRAME N+5 V 


past the data again without moving the 
straightedge used as a guide. 

The FRAMEID field contains an 8 bit 
identification of the current frame within an 
extended block of data. This identification is 
required in order to allow the user an option 
to reload data if a check sum error is 
detected. 

The length of the data is specified by the 
LENGTH field as a byte count from 1 to 
255 (actual counts will depend upon data 
density, but will most likely be less than 50 
per frame). 

Figure 3 shows the page layout to be used 
in a typical magazine page size of 7 inches 
wide by 10 inches high (18 cm by 25 cm). 
From his experimental work, Walter Banks 
reports that a bit density of 50 bits per inch 
(20 bits per cm) in the ratio recording 
method looks quite reasonable. Based on 
this linear density, and putting 1/5 inch (0.5 
cm) spacing between frames in the horizon- 
tal direction, the page capacity of the layout 
in figure 3 can be calculated: 


Bits per frame = 50 ВР] * 10" = 500 
Bits per page = 5 frames per inch * 7" * 
500 bits per frame = 17,500 


Overhead of the frame format in figure 2, 
excluding timing bits, is 32 bits per frame, so 
the total data capacity is 17,500 — 35 * 32= 
16,380 bits. In bytes, this is 16,380/8 = 
2047.5 bytes. The actual frame parameters 
would be adjusted to an even number of 
bytes, whatever the format employed. Using 
the fixed format, each page can hold 2 К 
(2048) bytes with the density figures re- 
ported. Shrinking the interbit gaps to the 
format 3 fixed size would probably give an 
improvement of 5 to 15 percent depending 
upon the width parameters chosen and the 
statistics of the data being presented in this 
form. 
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How Is the Data Generated? 


The secret of this whole method at the 
magazine production end is using modern 
phototypesetting equipment to create the 
images of the data which are used in the 
magazine master layouts. When (for exam- 
ple) an article describing an advanced high 
level language interpreter written by a uni- 
versity or basement lab hacker is to be 
printed, the paper tape or magnetic tape text 
of the program and its relocatable loader 
would be converted into phototypesetting 
commands for the typesetting equipment, 
on 9 track tape or paper tape compatible 
with the typesetter. Once the copy is re- 
ceived from the typesetter, the rest of the 
layout is standard operating procedure for 
any magazine — keep track of the order of 
the program pages and add any auxiliary 
copy needed to identify pages or segments 
within the program. With 2K bytes per 
page, dissemination of an 8K to 10K 
package would only require four or five 
pages in the magazine, and would be easily 
accomplished. We expect to perform experi- 
ments with this sort of dissemination 
technique in future editions of BYTE. 


Will It Work? 


The experiment looks quite reasonable, 
but there are numerous possible hitches 
which can be considered. For example, will 
the data density projected (50 bits per inch, 
20 bits per centimeter) be practical? What 
will be the incidence of errors due to ink 
splotches and other glitches? Will the simple 
conception of a reading head (photo tran- 
sistor, TTL level converter and straight edge 
as a guide) provide the signal needed? This 
report is written on the basis of preliminary 
experiments; further information on this 
subject will appear in future BYTEs.m 


Here's SCELBI's First Book of 

Computer Games for the 8008/8080. 
Action-packed. And fun. 

Try to beat the computer at its own game. 
Here's the first complete machine language 
computer manual for computer games to 
include source listings, flow charts, 
routines and more. Space Capture — You 


^ 
єє | against the computer using “search and 


всего 
Piel 
d ға destroy” strategy to shoot down roaming 
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ur 
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Introducing SCELBAL, 
the new microcomputer 

language that's simpler 
than machine language. 


ue — а mini-chess game that lets the 
(or the noo computer make mistakes... but only 
OI en once. Hangman — an updated version 
of the great kid game. Computer selects 
words at random from long, expandable 
list. Try to beat it in 8 moves or less. 


А alien spaceships in outerspace. Hexpawn 
бель 


Gau 


A complete language for 
'8008'/'*8080" systems 


including source listings `4 out yt Illustrated. Fun extras to put your. 
routines "low charts Md sux "ң | computer to challenging, competitive, 
more! fun use. 


95 
Order yours today! 14 ppd. 


el Seat Sei ИЙЕ. | SCELBI’s new microcomputer 
5 2 ientific ELementary uter Space... ^ 
BAsic Language for *8008"/"8080" / „ыйанан ONE 
systems. À complete, illustrated program book. Routines. against the logic of your "8008" or -— € 
Techniques. Source Listings. Flow Charts. And more. “8080”. You must destroy a random R g" 
Took several years to develop. Now yours for many years number v) ships without running К 
to come. First time that intimate details of higher level of ammunition or out of the galaxy. 
language has been offered for such a low price. Only $49! Plan your mission. How much fuel is 
You get 5 Commands: SCR, LIST, RUN, SAVE, LOAD. usod Лог (Т nae SSE Dr 
a bait, МЕХ T RETURA ane | ЗЕ 
D , ' ! 1 sigi ow blg is he ire a phasor or 
optional DIM. 7 Functions: INT, SGN, ABS, SQR, RND, torpedot не ОАЫ Ны сық Чез: 
CHR, TAB. And, it runs in 8K and more. Here's all the Just the beginning. A new game every 
data needed to customize a high level language for your time. Gomplete program book їп, machine Г " а 
і memory, inclu et 4 
system... at a fraction of the cost! КҮНҮ x s nar cluding ad «x d 
Order your copy today! Get $49 Great intergalactic adventure and fun. 1 Pe etm 
started advancing your system! ppd. 


Order "GALAXY" today! 1425 ppa. 


“8080” 


Ам 

SOFTWARE MANUALS f ^. 

Three new basic, Gom- — mented assembled listing | 
plelé "MUST" manuals! and more, $17.95. | 
“8080” Assembler Pro- "водо" Editor Program | 
gram operales easily In identica) to "BDOB" | 
4K bytes of RAM (Includ- — Editor, with machine A = | 
ing symbol table). Unique codes for "BOBO", 914,25, Mu corona we 4 | 
foature; How to accent x 2 = 


{ "8080" Monitor Routines 
TRA. none тое tenets шеті 
on “go80''. Includes all specifically developed 


ж- -- 
Yo ulifiz а - j — МӨ | 
major routines, pertineant а. 1 795 —' 44% = 11% “ыы 
Ном charts, highly com- $11.05, ора ppd 


. ppd. 
SAVE $5.35! BUY ALL 3 FOR ONLY $39.50! 


Now you can cook-up hot programs 
for your own 8080” 


Gobble up practical "how to" The "Cook Book" even in- 
facts, including the description cludes a completely assem- 
of "8080" instruction set. Ыва floating point arithmetic 
How to manipulate the ''8080 program ...plus input/output 
stack. Flow charts and source — processing for your basic 1/О 
listings. General purpose |, programming through inter- 
routines for multiple precision rupt processing. Code and 
operation. Programming time numeric conversion routines. 
delays for. real time аррса_. Real time programming. 

ions. Random number gener- А 
ЗАПИ many other Бес Search and sort routines. Апа 


қ А P 1 many, many more finger-lickin’ 
Prices shown for North American customers. programming function goodies. Order your copy of 
Master Charge, Postal and Bank Money Orders comestibles. Scelbi’s “8080” Software 
preferred. Personal checks delay shipping Gourmet Guide & Cook Book 
up to 4 weeks. Pricing, specifications, today. Only $9.95 ppd. 
availability subject to change without notice. 


Bon appetite! 
SCELBI COMPUTER 1322 Rear Boston Post Rd., Milford, CT 06460 
CONSULTING ERE, telephone: 203/874-1573 ` | 


Editorial 


by Carl Helmers 


The Address Space Saturation Problem 


(or, What Happens 
After You Use 32 
16 K Dynamic 
Memory Chips?) 


According to an article by Marvin Gold in 
the September 6 1976 edition of Electronic 
News, the 16 K dynamic memory chips are 
almost ready for volume production, and 
price estimates are quoted. According to Mr 
Gold's article, the 1976 average selling price 
of 16 K memory chips will be an estimated 
$16 each, and when volume production 
levels are reached in 1977, the average price 
at the factory will be $12. Assuming a 
personal computing company which has 
moderate volume production purchases the 
16 K memories at $12, its component cost 
for a 16 K memory segment is $96, and for a 
32 K memory segment is $192 in mid to late 
1977. Multiply this by a factor of 3 to 5 to 
take into account packaging, manufacturer 
profit margins, and merchant markup; and it 
can be expected that in mid to late 1977 the 
personal computer with 32 K memory will 
have a memory subsystem cost of perhaps 
$600 to $1000 at the retail store. 


Personal Computing 76: 


The designers of the early micro- 
processors never conceived of the large scale 
integration computer as anything more than 
a controller in dedicated applications (so the 
grapevine says). The rumor which was 
running around some time ago was that one 
LSI firm's reaction to the idea of a 
FORTRAN (or other high level language) for 
their microcomputer was "who'd ever want 
to do such a silly thing." The history of 
small general purpose computers imple- 
mented with LSI processors since then 
demonstrates that a lot of people want to do 
exactly that, and more: APL, SNOBOL, 
LISP, PASCAL, ALGOL, TRACTM etc, etc. 
Similarly, the reaction currently might be 
"who'd ever want to put more than 64 К 
bytes of memory in a personal computing 
system?” My claim is that there are plenty 
of people who would want to (in order to 


Continued on page 65 


Outstanding Computer Hobbyist of the Year Award 


by 
John Dilks 
Cochairman of PC 76 


At the Personal Computing 76 show, the 
members of the committee organizing the 
show felt it would be most appropriate to 
create an award for a person who has made 
some outstanding contributions to the prog- 
ress of computing by individuals. We se- 
lected the person, then dreamed up the 
award. The person is Sol Libes, president of 
the Amateur Computer Group of New 
Jersey. The award consists of a plaque for 
Sol to keep, and a second plaque with spaces 
for future entries to be engraved. This is how 
traditions are started. 

We had numerous reasons for wanting to 
present this award to Sol. Sol is employed as 
an educator, and is a true amateur interested 
in using the computer. He is one of the 
principal organizers of the Amateur Com- 
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puter Group of New Jersey, seeing it grow 
from a near handful of people last year to 
over 400 members with typically 200 
attending the many meetings. He is a leader 
in computer education, where at the Union 
County Technical Institute he has created a 
hands-on training program in microcomputer 
technology and has set up courses which 
could easily serve as prototypes for similar 
courses throughout the country. He set up 
and ran the Trenton Computer Festival of 
the ACGNJ, one of the first such happenings 
ever. And, during the past summer, he and 
his family travelled throughout the USA, 
meeting with amateur computer clubs and 
club leaders and manufacturers both to find 
out what's happening and to further the 
development of the field. We think these 
reasons more than justify the recognition, 
which was a complete surprise to Sol and his 
family at the banquet August 28. We hope 
to continue this award and tradition at 
future Personal Computing shows.@ 
` 


Мее the Challenger: 


The Challenger 
Self Portrait 


The new price and performance champ from OSI. 


He’s got his act together! 

Even our lowest-cost Challenger 
comes fully assembled, complete 
with а 500 ns 6502А, serial interface, 
1,024 words of memory and a 
UL-approved power supply, all for 
$439. Every Challenger comes ready 
for easy expansion with an 8-slot 
mother board, backplane expansion 
capability, and a power supply 
heavy enough to handle a full 
complement of system boards. Our 
4K Challenger comes ready to run 
BASIC minutes after you unpack it. 
And there’s more. 


He packs some heavy hardware. 


You've never seen memory and 
interface options like these—not at 
our prices, fully assembled! 4K 

RAM memory boards $139! (see 
below). Single drive OSI Challenger 
Floppy Disk $990! Dual drive 

Floppy $1490! Plus 8K PROM 
boards! A Video Graphics board, 
including alphabetics, graphics, 

and color! An audio cassette, 

A/D, D/A and parallel 1/О board! 

A backplane extender board! 

A prototyping board! And our extra- 
ordinary CPU Expander Board—it lets 
you run a Z-80, and 6100 (PDP-8 
equivalent) concurrently with The 
Challenger's6502, or under its control. 


There's nothing soft about 

his software! 

OSI has full software support for our 
Challengers. Including extended 
BASIC, extended Video Monitor, a 
Disk Operating System, some 

very Hollywood real time programs 
for Video Graphics, Animation, 
Sound Processing and so forth, plus 
PROM firmware, with more to come. 


He's fast! 

You can order The Challenger with 
а 6502C for a 250 ns cycle time, 
with a standard 6502A for 500 ns 
cycle time, or with a 6800 for 1 
microsecond cycle time. And with 


our CPU Expander Board, you 
can always update to any new CPU 
to be as fast as fast can be. 


And he isn't just good! 

He's better! By design. The OSI 
Challenger is the only completely- 
assembled, ultra-high-performance, 
fully-expandable mainframe computer 
that does this much for this little. 
Get your hands on one now. 

Send for your Challenger today. 


You can’t beat The Challenger! 
The OSI Challenger 65-1K. Fully 
assembled. Features 6502A CPU, 
serial interface, 1,024 words of 
memory. $439. 

The OSI Challenger 65-4K. Same as 
65-1K but with 4,096 words of 
memory. Will run Tiny BASIC with- 
out expansion. $529. 

The OSI Challenger 65V-4K. NO 
NEED for an expensive terminal. 
Connects to your ASCII keyboard 
and video monitor through included 
OSI 440 Video Board. Features 
software utility that simulates a 
deluxe CRT terminal. $675. 

The OSI Challenger 68-1K. Based 
on 6800 CPU. For the casual 
hobbyist, smaller systems. The 
Challenger 68 series comes only in 
serial interface forms and is 
compatible with MIKBug software 
through an included OSI software 
utilities package. $459. 

The OSI Challenger 68-4K. With 

OSI 4K BASIC on paper tape. $529 
SPECIAL! ADDITIONAL 4K MEMORY 
BOARDS. Ordered with your Chal- 
lenger, limit 3 more at this special 
Low Price, (total 16K, including 4K 
already on-board in mainframe). $139 
Buy 12K or larger Challenger 65 
system and we include Extended 
BASIC FREE! 


OHIO SCIENTIFIC INSTRUMENT 
Dept. В 11679 HAYDEN STREET, HIRAM, OH 44234 


OSI Challenger Floppy Disk System. 
Fully assembled, for use with OSI 
Computers only. $990 Single drive 
$1490 Dual drive. 

OSI Audio Cassette Interface. 
Comes assembled, but with room 

for you to populate with A/D and 
D/A chips later. (OSI 430 based) $89 
And all the baseboards and kits of 
the powerful OSI 400 System. 


OK, OSI, I’m ready to buy! 

To order your Challenger System, 
send the total amount of your 
purchase plus $4.00 for shipping and 
insurance (plus sales tax for Ohio 
orders) by personal money order or 
check. Or indicate all numbers 

on your BankAmericard or Master 
Charge to charge your order. 

Or send a 20% (non-refundable) 
deposit to receive your order C.O.D. 
Delivery is typically 60 days (except 
when payment is by check, which 
must clear before shipment can be 
made). Deliveries are scheduled on 
a first ordered, first shipped basis. 


Name. 

Address 
City.  . | . State 
Telephone. 

Bank card info Inter Bank # 


Zip. 


Expiration Date. 
Account # 


Check[] M.O.[] ВАСО MCO 
20%, bal. C.O.D. Г] 

П Order attached. 

Г] Send additional informa- 

tion on The OSI Challenger. 
П Send additional informa- 
tion on OSI 400 Kits. 

Ex м C] $1.00 enclosed 

for complete 

OSI Catalog. 


(216) 569-7945 


HAVE A MERLIN 


The Intelligent Video Interface 


If your favorite computerist has ап 8080 bus system, what better way to say Merry 
Christmas than with a MERLIN Video Interface? MERLIN is not just a superb 
character display . . . MERLIN is a whole system... 
MERLIN is a text display, 
a high density graphics display, 
a keyboard interface, 
a serial І/О port, 
a regulated power source, 
a RAM/ROM memory and 
an integrated and expandable software package. 
MERLIN is a gift that keeps giving. MERLIN's keyboard and I/O connector allows the 
MERLIN owner to add a variety of MiniTerm hardware expansion products. 
MERLIN's software has been written as an expandable ROM system with many 
general purpose subroutines available for use. Give your favorite computerist 
(yourself, perhaps?) a MERLIN Christmas! 


Order early to insure delivery for Christmas. 


FIRMWARE SPECS 
MERLIN'S BASIC INTELLIGENCE (МВ!) ROM has 


Monitor Functions 


1 @@ 24 QE 02 CD 33 F 
Ei CO 25 36 CD 06 3 
CD CE 33 ©З 24 398 


Memory Fill with HEX value 
HEX Memory Dump 

ASCII Text Input 

HEX Memory Input or Modify 
338 Set Display Format 

* Examine/Modify CPU registers 
Copy Memory Blocks 

Define Display Memory Area 
Four User Defined Functions 
Execute User Program 

Three Auto-Clear Breakpoints 


++ . ы + > 
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«ES 
1234 5678 6840 Editing Functions 


H NE 
WAIT UNTIL YOU SEE ALL THES Winking Keyboard Cursor 
Cursor up, down, rt, It, & Home 


ШЕШЕ FUNCTIONS (ALL 21 OF ТНЕМ! Ж 
insert and Replace Mode 


Delete Character and Line 

Delete to end of ‘Display Memory’ 
Four Slave Cursor Functions 
Auto or Manual Scroll 
Home/Clear 

Six User Defined Functions 

Page Up and Page Down 


Monitor/Debugger Example 
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CHRISTMAS ! ! ! 


HARDWARE SPECS 


* Altair/IMSAI Plug-in Compatible 
(Other Computers Soon) 
* 40 Character by 20 line ASCII Display Format 
“ 5 by 7 font, 64 Character Generator ROM 
* Dual Resolution Graphics: 
100 V by 80 H or 160 H 
* Mixed ASCII/Graphics Mode 
* Program Control of: 
Cursor: On/Off 
Control Character: Inverted/Blanked 
Carriage Returns: Displayed/Blanked 
FIXED or FREE (Memory Saver) Format 
Video: Black on White or Reversed 
ASCII, Graphics or Mixed Mode 
* Plug-in Keyboard Port 
* DMA makes MERLIN the fastest display available 
—over 48 K characters per second 
* Sockets and Decoding for on-board Memory: 
Two 2708 1 K X 8 EPROMs, or 
Two2K X 8 Mask ROMs, and 
One 256 X 8 Scratch Pad RAM 


PLC c cc not 
ма 
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MERLIN 


Nannette "7! [ БАА wy 


160H X 100V Graphics 


MERLIN is just the beginning . . . coming soon аге... 


* Game control boards that interface via MERLIN's 
Serial 1/О Port 
* Joystick input board for graphics drawing, also via 
MERLIN's Serial I/O Port 
* 1500 Baud Cassette Interface via MERLIN Serial 1/0 
with software for less than $30! 
Color Graphics and Super Dense Graphics option board 
for MERLIN. 
Modem board so you can play computer/computer 
games with your friends. 
* High Speed Multiple Cassette Interface Board with 
on-board ROM intelligence 
* Keyboard and Enclosure to plug into MERLIN's 
Keyboard and I/O connector. 


* 


ж 


O MERLIN: assembled and tested including manual 


(Does not include Метогу).................... $349.00 
O MERLIN: kit containing PC boards, IC sockets, User 
Manual and all parts except memory ............ $249.00 


О MBI MERLIN's Basic Intelligence: 256 X 8 RAM 

and 2K X 8 mask ROM containing Monitor/Editor .$ 39.95 
П ME! MERLIN’s Expanded Intelligence: 2K Х 8 mask 

ROM with more Monitor/Editor functions and 


Graphics sübroutineSm. „а cs Vase ee eens $ 34.95 
[1 MERLIN User Manual: over 100 pages of detailed 
hardware and software documentation .......... $ 8.00 


FS 


Name 

Address 

City ——— State |. . Zip 
Signature 

Total $ MC/BA #— /. .  .) — .Exp. 


All prices subject to change without notice. Mass. residents 
please add 5% sales tax. Master Charge and BankAmericard 
accepted. 


MiniTerm Associates 


Box 268, Bedford, Mass. 01730 


Readers Beware! | 


APL is often thought of as heavy mathe- 
matical stuff. Terminology used іп this 
article reflects this background and is sum- 
ed in the glossary; table 1 should be 
referenced when reading the text to identify 
operations coded by the special symbols of 
APL. The symbols used in this article are 
sometimes approximations of a true “APL” 


' for a Selectric typewriter. Many of the 
bols are printed on the typical APL 
minal using multiple overstrikes (ie: the 
sequence: character 1, backspace, character 


What Is APL? 


Mark Arnold 
1400 Grand Av 
Laramie WY 82070 


About the Author: 


Mark Arnold is a stu- 
dent at the University of 
Wyoming, Laramie WY. 
His experiences to date in- 
clude | co-authoring the 
SCELBAL interpreter pro- 
gram with Nat Wadsworth, 
He is currently at work on 
the definition and imple- 
mentation of an APL sub- 
set interpreter for micro- 
processor systems. 


APL is the modest name of A Program- 
ming Language, created by Kenneth lverson. 
APL is simple to learn, yet in many ways it 
is the most powerful language in use today. 
While to the untrained eye APL looks like 
the strangest computer language around, 
with the possible exception of LISP, the 
structure of APL is fairly close to that of 
more common languages such as FORTRAN 
or BASIC. This article will look at some of 
the features of a large system APL. Also, | 
will explore what features | think a small 
APL system for a microcomputer could 
have. 


Writing in FORTRAN is like writing how 
to go downtown: You don't have to think a 
lot about what parts of the language you 
use; you just tell exactly what to do. Writing 
in APL is like writing poetry: You want to 
use the exact part of the language that will 
express what you want without any excess. 
APL haters criticize APL because there are 
so many operators for the user to remember, 
and the code doesn’t always flow out with- 
out some thought, but APL enthusiasts like 
APL because the large number of operators 
greatly reduces the size of programs. 

APL is extremely time-efficient (at least 
on large computers) for parallel operations, 
such as adding two sets of numbers together. 
Suppose your program was to figure out the 
bowling average of each of the four players 
on your team. In most languages you would 
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have to use a loop which would go around 
for each time there was a new score. In APL, 
all you would need (provided the program 
was set up right) would be a +. 

APL operates as an interpreter; that is, it 
looks at the APL language program and does 
the operation (perhaps after some inter- 
mediate translation). This is different from a 
compiler which translates to machine lan- 
guage before the program is run. Because of 
this, there are two states in which you 
operate APL. The first is called evaluated 
input and the second is called function 
definition. “Function” is the APL name for 
what would be called a “program” in other 
languages. A workspace is all the functions 
and variables that you have created. There 
can be more than one function in a work- 
space, and often you can save the workspace 
on an auxiliary storage device. 

The evaluated input mode is as simple as 
1*1. When evaluated input is in control, 
APL prints six spaces and requests input. If 
you type 1+1, APL will print out the sum of 
1 and 1. It would look like this (where the 
indented part is what you type and the 
answer is printed out starting at the left 
hand margin) 

1+1 USER —» 
2 — АРІ 


Notice that по “Print Statement” is песеѕ- 


sary as it would be in BASIC. Some common 
operators are +, —, x, т. These are the 
normal math symbols for the basic opera- 
tions, but not the normal BASIC and 
FORTRAN symbols. The original APL used 
these and many more strange characters for 
its operators, and since the first APL systems 
were implemented оп 1BM/360s, this was no 
major problem. Changing a character set 
simply meant changing balls on a Selectric 
terminal. Most of the operators have two 
meanings (as summarized in table 1 for all 
APL operators). The example above of 
adding 1 to 1 is known as dyadic; that is, the 
addition operator has two operands: the one 
on the left and the one on the right. The — is 
an example of а monadic operator that has 
only one operand on the right: 


-3 USER —* 
73 +— APL 


The -3 calculates the minus of 3. APL 
responds with 773, which is its way of saying 
"negative three." Note: The 7 is used only 
with numbers, while the — can be used in 
any expression. 

APL scans an expression from the right to 
the left which is opposite the way most 
high level languages do. This means 2—3—4 
yields 3 instead of 75. [in APL, a raised 
hyphen indicates an algebraic negative sign 
and an ordinary hyphen is used for subtrac- 
Поп./ Also unlike most high level languages, 
there is no algebraic hierarchy in APL. So 
2х3+4х5 is 56 and not 26. However, as in 
other high level languages, parentheses can 
be used to override the right to left conven- 
tion: (2x3) *4x5 is 26. 

All the expressions shown up to now have 
been of scalar values, that is, single numbers. 
APL also allows vectors as constants. A 
vector is an ordered set of scalar values, 
something like an array in FORTRAN or 
BASIC. So to figure the average of the two 
scores of the four members of your bowling 
team: 


.5 x 160 109 300 240 USER —* 
+ 203 157 254 165 USER — 


181.5 133 277 202.5 *—— APL 


where player one bowled 160 and 203, 
player two 109 and 157, and so on. The first 
thing APL does is to add the two vectors 
(scores) in parallel to get 363 266 554 405. 
Then each one of the four sums is multiplied 
by .5 to produce: 181.5 133 277 202.5, the 
average of those two games. All of this was 
done without an explicit loop or any pro- 
gram in the evaluated input mode. (Note: To 
do an operation, either the size of the two 


Table 1: APL Operators. This is a complete listing, abstracted from the 
sources in the bibliography of this article, of the APL operators implemented 
in a typical large scale system such as an 1BM/360 or 1BMÍ370. The ІВМ 5100 
machine is reported to run the full set of APL functions by emulating a 
360/370 architecture in microcode and using close to 200K bytes of 
interpreter ROM. A practical small system APL would necessarily be a subset 
if the interpreter is to be kept to a small size. 


Monadic Scalar Operators 
+ Identity: Returns the right operand as though the operator had not been there. 


Minus: Returns the negative value of the right operand. (Appears above normal 
position of minus sign as in — 3.) 


x Signum: Returns 1 if the right operand is greater than zero, O if it is equal to 
zero, and ТІРІ is less than zero. 


т Reciprocal: Returns the reciprocal of the right operand. 

ж Exponential: Returns е raised to the right operand, 

Natural Logarithm: Returns the LOG base e of the right operand. 

Floor: Returns the greatest integer less than or equal to the right operand. 
Ceiling: Returns the least integer greater than or equal to the right operand. 


Absolute value: Returns the absolute value of the right operand. 


"dr e 


Factorial: Returns the factorial of the right operand. 
о Pi times: Returns Pi times the right operand. 


4, Not: Returns а 1 if the right operand is 0, О if the right operand is 1; an error 
condition results if the operand is not logical (1 or 0). 


? Roll: Returns a random number between 1 and the operand. 
Monadic Mixed Operators 

, Ravel: Converts а higher dimensioned array into а vector. 

1 Index generator: Returns a vector of consecutive integers between 1 and the 
right operand. 

р Shape: Returns the length of a vector or the dimensions of a higher dimensioned 
array. 

A Grade up: Returns a vector that when used to index the right operand will sort 
it into ascending order. 

ү Grade down: Returns a vector that when used to index the right operand will 
sort it into descending order. 

€ Execute: Returns the value of an expression represented by character data as 
though the characters value of the right operand had been entered during 
evaluated input. 

[+] Matrix inverse: Returns the inverse of the matrix specified in the right operand. 

є Monadic transpose: Returns a matrix such that the rows of the right operand 
are the columns of the new matrix. 

ф Reversal: Returns a vector (if the right operand is a vector) where the elements 
of the vector are in the reverse order of the right operand. 

Dyadic Scalar Operands 

+ Addition: Returns the sum of the right and left operands. 

- Subtraction: Returns the difference of the right and left operands. 

x Multiplication: Returns the product of the right and left operands. 
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Table 1, continued: 


ele 


[A 


“ 


operands must be the same or one must be а 
scalar and the other an array. An operation 
such as + or x is called a scalar operator 
because it obeys this rule.) 


Division: Returns the quotient of the right and left operands. 
Exponentiate: Returns the left operand raised to the right operand. 


Logarithm: Returns the logarithm whose base is the left operand, of the right 
operand. 


Minimum: Returns the minimum of the two operands. 
Maximum: Returns the maximum of the two operands. 


Residue: Returns the remainder resulting from the division of the left operand 
by the right operand. 


Combinations: Returns the binomial coefficient of the left and right operands. 


Circular functions: Returns the function of the right operand where the left 
operand specifies which function: 
Function of —X 


Left operand Function of X 


0 1-Х same 

1 Sin X Arcsin X 
2 Cos X Arccos X 
3 Tan X Arctan X 
4 1+х2 х2—1 

Б Sinh X Arcsinh X 
6 Cosh X Агссовһ X 
7 Tanh X Arctanh X 


Less than: Returns 1 if the left operand is less than the right operand, and 0 
otherwise. 


Less than or equal to: Returns 1 if the left operand is less than or equal to the 
right operand, О otherwise. 


Greater than: Returns 1 if the left operand is greater than the right operand, О 
otherwise. 


Greater than or equal to: Returns 1 if the left operand is greater than or equal 
to the right operand, 0 otherwise. 


Equal to: Returns 1 if the left and right operands are equal, O otherwise. 


Not equal to: Returns 1 if the right and ieft operands are not equal, О if they 
are. 


And: Returns 1 if both left and right operands are 1, O if either or both are О. If 
one of the operands is not 1 or O then an error results, 


Or: Returns 1 if either one or both of the operands is 1, O if both are 0. If 
operands are not logical (1 or 0) an error will result. 


Nand: Returns O if both right and left operands are 1, 1 if either one or both аге 
0. If operands are not logical an error will result. 


Nor: Returns 1 if both right and left operands are О, О if either one or both are 
1. If operands are not logical an error will result. 

Dyadic Mixed Operators 
Deal: Generates the number of random numbers specified by the left operand, 
between 1 and the right operand, such that there is no repetition of the 
numbers. 
Index of: Returns the subscript to the left operand where the first occurrence of 
the right operand can be found. If the right operand is not found in the left 


operand then one plus the length of the left operand is returned instead. 


Catenation: Returns the two operands joined together as one vector (or array). 
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Another type of constant is the character 
type. 'A' is a character scalar constant and 
‘ABCD’ is a character vector. A character 
vector in APL is roughly equivalent to the 
character string as implemented in languages 
like Extended BASIC, PL/1 or XPL. 

Any legal left operand can be subscripted 
by using the brackets. 


33 443 34 [1 3] USER —* 
gives a two element array 
33 34 *— APL 


In this case a three element array is reduced 
to two by choosing elements 1 and 3. 

A variable, whose name can be up to 31 
characters long, is assigned a value by the 
assignment arrow. 


For example: 
D-009 USER —* 
A-1234 USER — 
Be 567 4 USER —> 
Се A+B USER — 
D [1 2]« СІЗ 4] USER —> 
с USER — 
6 8 10 0 4—-APL 
D USER —-» 
1009 4— APL 


Notice that an assignment suppresses thc 
printing of a value. In this example D is 
given the vector value 0 09. A is given the 
vector value 1 23 4, and B is given the value 
567 4; Сіѕ the sum of these two vectors. 
The first two elements of D are assigned the 
last two of C. Character data can also be 
assigned to a variable, such as 


MESS<'This is a message'USER —* 
MESS USER —» 


This is a message +— APL 


Some of the operators listed in table 1 are 
very important to APL programs. One of 
these is the monadic iota, known as the 
index generator, which creates a vector of 
consecutive integers from 1 to the value of 
the operand. This operator can be used to 
eliminate many loops from programs. For 


example, if you wanted to calculate the 
cosine of a number using the Taylor series: 


| х2 4 x4 | (-1)0-1х2-2 
2! 4! (21-2)! 


(instead of using the 2°X function) this 
expression would do it, where N is the 
number of terms to be calculated. 


USER — 
USER —* 


+/ (1*1 +1N) x (X* 
2x7l4iN)* ! 2x 1+1N 


The subexpression 2x 1+1N will generate 
N even integers, while this same expression 
is used to calculate factorials. The powers 
and the factorials are divided in parallel and 
multiplied by the 1 11 1... generated 
by (Ci*i«N) The +/, called a plus reduc- 
tion, sums up each one of the elements of 
the vector which contained the quotients of 
the powers and factorials. Another example 
of plus reduction would be to average the 
vector 2 34 5: 


(4/2345) #4 USER —* 


Any other dyadic scaler operator could have 
been used; for example, instead of the 
built-in factorial operator, the factorial of a 
scalar J could be calculated by: 


x/ J USER —* 


Two other operators that eliminate loops 
are Ше grade up and grade down operators, 
which function similarly. They are monadic 
only. The grade up gives a vector of the 
subscripts to the given vector so that if the 
vector is subscripted by its grade up it will 
be sorted in ascending order. For example: 


А 64735 USER —* 
ha USER —> 
42513 *— APL 
А (hal USER —> 
34567 «—— APL 


Suppose the scores of the players on your 
bowling team were in a vector subscripted 
by player number (as in previous examples); 
then if you wanted to display the ranking of 
players, best to worst, simply do a grade 
down: fa. 

One of the most interesting operators of 
APL is the execute operator, sometimes 
represented as $ or є which takes a character 
vector and performs operations as if the 
characters had been input during evaluated 
input. 


Table 1, continued: 


p 


L 


-e- 


+ t+ »r31-4[ [| + 


Reshape: Returns a vector (or array) created from the elements of the right 
operand, such that the shape of this new vector equals the left operand. 


Decode: Returns the base value, where the left operand is a vector of base 
weights, and the right operand is a vector of base representation. For example: 
1010101234 is 234 and 222 1101155. 
Encode: Returns base representation as a vector, where the left operand is a 
vector of base weights, and the right operand is the base value. For example: 
ТО 10 107 234 15234 and 22 215 5 10 1. 


Take: If the left operand is positive, МТА returns the first N elements of 
A. If the left operand is negative, (—N)t A returns the last N elements of A. 


Drop: if the left operand is positive, NIA returns a vector with the first М 
elements of the right operand removed. If the left operand is negative (-М))А 
returns the last N elements dropped. 


Membership: For each element of the left operand, membership returns a 1 if 
the element is contained in the right operand, О otherwise. 


Matrix divide: Returns the solution of simultaneous linear equations, where the 
left operand is the vector of the constants, and the right operand is the matrix 
of the coefficients. 

Dyadic transpose: Often used to find the diagonal of a matrix. 

Rotation: Returns the right operand rotated the number of elements specified 
by the left operand (to the right if the right operand is negative, to the left if the 
right operand is positive). 

Compression: Returns a vector (ог array) where the elements of this vector were 
selected from the right operand when the corresponding element of the left 
operand was 1. If the left operand is not logical an error results. The length of 
the left operand must be equal to the length of the right operand; but it does 
not entirely obey the rule for scalar operators, since the result will have a length 
which is equal to the number of 1s in the left operand. 


Expansion: Returns a vector (or array) with zeros inserted in the corresponding 
positions of the right operand wherever there is a zero in the left operand. 


Composite Operators 
(where f and g are any dyadic scalar operator) 


Reduction: Performs the operation on the elements of a vector (or array), right 
to left. 


Scan: Performs the operation on the elements of the right operand, left to right, 
and saves the results in a vector, which is what it returns. 


Generalized matrix product: A+.xB is normal matrix multiplication. 

Outer product: Can be used to generate multiplication tables, etc. 
Special Operators and Characters 

Assignment: Stores the expression on the right in the variable on the left. 


Quad: Requests an expression for input and returns the value of the expression. 
Also used for output. 


Quote-quad: Requests a character value to be input. 

T-bar: For information about variable type, and character generation. 

І-Беагп: Returns system dependent information. 

Comment: APL ignores all characters to the right. 

Del: Used to open and close functions. 

Branch: Continues execution of a function at the line whose number is equal to 


the value of the expression on the right. Branch to empty value branches to next 
line, branch to O stops the function. 
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Еог ехатр!е: USER —> 
є'1+1' «— APL 

2 USER — 
кегі: USER ——> 

Ber]! USER —> 
ЄА,'+',В +— APL 


The comma is the catenation operator, 
which takes the vectors and forms a new 
vector of the old two joined together, so 
‘+’. B forms ‘+1’ апа A,‘+1’ forms ‘1+1’. This 
is then evaluated by the execute operator 
which gives the numerical result of 2. 
Catenation can also be used on numeric 
vectors: 


A«1 2 3 USER -> 
Вє5.5 4.7 3 USER — 
A,B USER - — 
1235.54.7 3 «—— APL 


To create an APL program (function) you 
must leave the executive or evaluated input 
mode, and enter the function definition 
mode. To do this, type the del (9) and the 
name of the function you wish to create. 
For example, to create a function called 
NEW type: 


VNEW USER: — 
to which APL would respond: 
[1] «— АРІ. 


You would then type the first line of the 
function, and continue until all the function 
is entered, or until you want to leave the 
function definition mode, which you can do 
by typing another del. Here is a sample 
function: 


VNEW USER --—> 
[1] «—— APL 
№-0 USER - 
[2] 4—— APL 
NeN+1 USER — 
[3] +— APL 
N USER -— 
[4] +— APL 
> (N#10) /2 USER - — 
[5] + АРІ 
'FINISHED' USER —» 


To run this function, simply type its 
name: NEW. 
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This function starts at line 1 by initial- 
izing the counter М to 0, then it proceeds to 
line 2 where the counter is incremented. At 
line 4, N is compared to 10, and since they 
are not equal a result of 1 is produced, 
which allows the 2 to pass through the com- 
pression operator (see table 1). Тһе > is 
the symbol for branching, so branch to 2 
in the above example takes control back to 
line 2, where N is incremented again. The 
loop continues until N210, in which case 
№10 returns a value of 0. This causes the 
compression operator to return a null value. 
Branching to a null value is the same as 
branching to the next line in the function, 
which in this example prints out FINISHED. 
Since there are no more lines to execute, 
execution of the function stops, and APL 
prints out six spaces like normal. The output 
of this function would look like this: 


NEW USER —* 
1 
2 
3 
4 
5 
6 я APL 
7 
8 
9 
10 
FINISHED 


This program is not a very useful one, 
since the iota could be used to get essentially 
the same result, but suppose you wanted to 
change thts function to output a table of 
numbers and their squares. First you would 
reenter the function definition mode, and 
type [3] to say that you wanted to change 
line three. You would type in: 


[3]N;' ';H*2 OSRE * 
The semicolon separates things to be printed 
on the same line. You decide you want a 
header on the output, so you type (1.5] to 
insert a line between 1 and 2. Then you list 
the function by typing D (the box is called 
a quad, and is also used for input and output 
within an expression). 


[1] N«0 *—— APL 
[1.5] 'TABLE OF SQUARES' «*—— APL 
[2] N<N+1 4—— APL 
[3] N;N*2 «—— APL 
{4] *(N£10)/2 «—— APL 


Everything looks OK, so you close the 
Continued on page 123 


HOW TO SAVE HUNDREDS 
OF DOLLARS ON PARTS. 
PAINLESSLY. 


At CSC, we've developed a family of ingenious Design Mate" test 
equipment that gives you professional quality and precision 

at very unprofessional prices. Each unit can save you 

money—and time—in a number of interesting ways. 

For more information on these, or any other 

CSC products, see your dealer or write 

for our catalog and distributor list. 


SAVE MONEY AND TIME 
WITH DESIGN MATE 1 

This precision all-in-one unit 
combinesyja solderless plug-in 
breadboarding system with a 
built-in better-than-1%- regulated 
variable 5-15V supply and 
0-15V voltmeter. Gives you 
everything you need to design 
and test circuits faster than 
you ever could before. 
Saves money by eliminating 
lead damage and heat 
damage to components. 
Lets you re-use parts over 
and over again, to save 
even more. All for just 
$54.95* 


STRETCH YOUR BUDGET FURTHER 
WITH DESIGN MATE 2 
Precision function generator lets you 
test all kinds of equipment, with 1Hz- 
100kHz signals. Low-distortion sine 
waves, high-linearity triangle waves, 
fast-rise-time square waves. Five 
decade ranges, accurate to 5% of dial 
setting, with variable 100mV-10V P-P 
output and constant 600-ohm 
impedance. At $69.95* it's alot of 
signal for very little money. 


SAVE MORE MONEY AND TIME 
WITH DESIGN MATE 3 
Accurate R/C bridge helps you use 
"bargain" components. Quickly and 
easily measures resistance 10 ohms—10 
meg; capacitance 1OpF -1uF—both in 
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eu See о New Haven ст ЕС ЧТЗ OS StS NA. 710-465-1227 
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Photo 1: This image was 
inspired by the article's 
title (or was it the other 
way around?) The pro- 
gram of listing 1 was used 
to draw this picture as well 
as the others ассот- 
panying this article. 


In the past, graphics systems available to 
the experimenter have been expensive and 
complicated or have forced him to settle for 
limited resolution. The simple circuit de- 
scribed in this article will provide resolution 
of 128 by 128 dots for under $20 and four 
times that resolution for just over $20. It 
requires the use of an oscilloscope as the 
display device, but it need not use an 
expensive scope. 

We can create images on the screen of an 
oscilloscope by using dots. By placing many 
dots close together, we can form lines and 
shapes or even letters and numbers. The 
location of a dot on the screen is specified to 
the oscilloscope by a pair of voltages, one 
voltage being applied to the scope's vertical 
input and the other to its horizontal input. 
The computer provides the voltage values by 
outputting two binary words to a pair of 
digital to analog converters (known as 
DACs). The converters produce output volt- 
ages that are proportional to the numeric 
value of the words. Because an 8 bit word 
will allow the DAC to produce any one of 
256 voltage values, it should be possible, 
using high precision 8 bit DACs, to position 
a dot any where in a 256 by 256 field. 

By providing a rapid sequence of many 
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binary word pairs, we can generate a large 
number of dots that all appear to exist on 
the screen at the same time. By repeating the 
sequence many times a second, we can 
display a steady, nonflickering pattern of 
dots. Each time we repeat the sequence we 
"refresh" the display. 

Because the time required for the com- 
puter to perform a refresh operation will 
depend, at least in part, on the number of 
dots being displayed, there will certainly be 
an upper limit to the total number of dots 
that we can display without a noticeable 
flickering of the screen. That limit is deter- 
mined by such factors as the speed of the 
computer, what the computer is doing be- 
sides refreshing the display, how the numbers 
are obtained (ie: whether they are computed 
or read from a buffer in memory), the 
persistence of the oscilloscope's phosphor, 
and what flicker frequency the user con- 
siders noticeable. For example, using the 
routine described later in this article on an 
8080 system with a 1 MHz clock (about half 
the speed of an Altair 8800) and using a 
medium persistence phosphor in the display, 
| find that | can display about 512 dots 
before flicker begins to appear. 


The Circuit 


The circuit of figure 1 uses components 
that are all readily available. Most can be 
bought through the suppliers who advertise 
in the back pages of BYTE magazine. The 
MC1408 digital to analog converters can be 
supplied by any Motorola distributor and are 
manufactured in several different levels of 
precision. The precision determines the 
exactness with which the output voltage will 
correspond to the binary input. The -L8 


Table 1: Integrated Circuit Power List. This 
list contains the pin connections for the 
power voltages used by figure 1. 


Integrated +5 V -V 
Circuit Type Power Ground (—7.1) 
ІСІ 74100 24 7 - 
ІС2 74100 24 7 - 
IC3 MC1408L7 13 2 3 
or 
MC1408L8 
ІС4 74100 24 7 - 
ІС5 МС140817 13 2 3 
or 
MC1408L8 
ІС6 7404 14 7 - 


Graphics Interface 


8 BIT BUS ІСІ ІС2 Ica +V REF 
LSB 74100 74100 MCI408 
DO су ТО SCOPE 
01 HOR. INPUT 
a, 
D2 
— бз 
OUTPUT | C» 
PORT adr 
505 R3 
=, 06 3300 
07 
" 
MSB 
v OUT 
APPROX 
О TO-4V 
ІС4 
74100 
m сү TO SCOPE 
VERT. INPUT 
R7 
3300 
+5V R6 
A 6800 
R4 
470 
ar 
[5 
XSTROBE 
+5V RESISTORS- 
^ 174W 
R5 VALUES IN OHMS 
470 
ar 
> 
Y STROBE 
2 l 
+5V BUS 


C) +7V<+<+35V 


c3 


30pF 
VOLTAGE DETERMINED 
BY VIN. 


TN 


BYPASS CAPACITORS (TYPICAL AT SEVERAL 
PLACES ON POWER BUS) 


R8 
330 
1/2У/ 


МЕЕ -BV«-V«-I8V 


Figure 1: Schematic for the Beer Budget Graphics System. This graphics system uses the computer's main memory as a refresh 
source, with a continuously executing program to put the position information out to the X and Y inputs of the oscilloscope. 
Both the X and Y outputs change "simultaneously, " limited only by the amplifier slew rates of the oscilloscope and the MC1408 


settling times. The driver program enables interrupts once per scan in order to allow a keyboard controlled drawing mode 
commanded by user inputs. 
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Photo 2: An illustration of 
how different dot bright- 
nesses are achieved by re- 
peating points. The cursor 
is a winking point, For 
user controlled brightness, 
extra time on a point is 
entered by pushing the 
“deposit key" (ASCII‘*’) 
multiple times using the 
program of listing 1. 


version should be used if a 256 by 256 
resolution is desired. The -L7 version may be 
used for a 128 by 128 resolution, but 
attempts to use it for higher resolutions will 
result in unevenly spaced dots. For low 
resolution applications (64 by 64 or less), 
the -L6 version provides an economical 
choice. 

This circuit is simple enough to bread- 
board using a socketboard array such as | 
did. Later, | made a permanent board as a 
double layer printed circuit with fake 
"plated through" holes of wire jumpers. It 
may also be constructed using wirewrap 
techniques. Leads, especially those associ- 
ated with the digital to analog converters, 
should be kept short; and | recommend that 
the lines going to the oscilloscope be 
shielded. A good ground connection to the 
oscilloscope is essential. 

The data bus is assumed to come from an 
8 bit parallel output port that can sink 6.4 
mA per bit line. | do not recommend driving 
this circuit without additional current buf- 
fering directly from the system data bus 
unless there are relatively few other devices 
on the bus. A dotted line in the drawing 
shows where a 17 line interface to an 
existing latched ІО port might be made, 
further simplifying the circuit. 

The strobe lines are active low and the 
entire logic O transition should take place 
while the data inputs to the latches are 
stable. The inverters provide current buffer- 
ing for the 74100 clock inputs as well as the 
appropriate logic 1 load signal. 

The digital to analog converters in the 
configuration shown in the schematic pro- 
duce a negative output voltage. As the 
numeric value of the binary word becomes 
greater, the output voltage becomes more 
negative. Note that with the MC1408 DAC 
the A8 input is the least significant bit and 
АТ is the most significant bit. 

Choice of an oscilloscope is not very 
critical. | have been using a battle-scarred 
Heathkit 10-102, which, until they stopped 
producing it, was the bottom of their line. 
The oscilloscope must have both X and Y 
inputs. If you have direct-coupled inputs, 
you may find them preferable at times, 
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though for most applications AC or DC 
coupled inputs can be used. Unless it is 
severely limited, bandwidth should not be a 
problem: 1 MHz or greater in both channels 
should be more than adequate. 

In normal operation, the horizontal co- 
ordinate is outputted first. The XSTROBE 
line is used to load that coordinate into the 
first latch of the horizontal channel. Note 
that it does not yet appear at the input of 
the horizontal digital to analog converter. 
The vertical coordinate is then outputted 
and loaded into the vertical latch by the 
YSTROBE line. This strobe signal also loads 
the horizontal coordinate into the second 
horizontal latch. Thus, the vertical and 
horizontal coordinates are both applied to 
their respective converters at the same time. 

If you find that the dots seem to vibrate 
or move about on the screen, you are 
probably picking up 60 Hz hum. Double 
check the ground connection to the oscillo- 
scope and use shielded cable if you are not 
already doing so. Streaked or smeared dots 
suggest excessive reactance on the lines 
going to the oscilloscope or severely limited 
bandwidth of the oscilloscope itself. The 
direction of the smearing gives you a clue as 
to which channel is being affected. Reducing 
the refresh rate may help to control this 
problem if all else fails. 


Some Software Considerations 


In many graphics applications such as 
game programs or interactive graphics, the 
computer is not merely being used to refresh 
a display but is also called on to perform 
other functions, in effect, at the same time. 
To allow maximum freedom for the com- 
puter to execute these other functions, the 
display refresh routine should be designed to 
operate quickly rather than, say, to save 
memory. Rewriting a dot output routine so 
as to save a few microseconds may not bea 
petty exercise if there are 512 dots to be 
refreshed 20 times a second. Such a savings 
might be obtained by using JUMP instruc- 
tions instead of CALLs or, if you are 
outputting from a buffer in memory, de- 
fining the limits of that buffer only in terms 
of the most significant address byte so you 
don't have to perform a time-consuming 16 
bit comparison to find out if you've reached 
the end of the buffer. 

It is also important to distribute the 
display refreshes evenly to avoid annoying 
flicker of the screen. If you decide, for 
example, to refresh the display 30 times a 
second, it will do no good to perform all 30 
refresh operations in the first half of that 
second. This would probably be a good 
application for a programmable interval 


timer which would generate ап interrupt 
when it is time to refresh the display. 

Note that it is possible to use the soft- 
ware to control dot brightness. By causing a 
particular point on the screen to be 
refreshed more often than other points, we 
can generate a brighter dot at that point. 
This may be done as simply as storing that 
dot in several locations in the buffer. 

The routine detailed in listing 1 was the 
first program that | wrote for the graphics 
circuit. It is written for use with an 8080 
instruction set and is basically a picture 
drawing routine. It has a 512 dot buffer, a 
winking cursor, and it recognizes six com- 
mands: move cursor right; move cursor left; 
move cursor down; move cursor up; deposit 
a dot (at the cursor location); and, clear 
display. Because this routine uses a fixed 
buffer size, the clear is performed by sweep- 
ing all 512 dots into a pile in the lower left 
hand corner of the display (coordinate: 
ЕҒ,ЕҒ). Each command is indicated with a 
single ASCII character inputted from ап 
interrupt driven keyboard. The interrupt 
service routine merely loads the accumulator 
from the input port and returns to where it 
was called from. Because | use "memory 
mapped” IO (ie: my IO ports are treated as 
memory locations), | use STA as an output 
instruction. Those using 8080 IO instruc- 
tions will want to substitute OUT instruc- 
tions. 

Consider what the routine has to keep 
track of. When refreshing the display, we 
have a pointer (HL) that tells us which dot 
in the buffer we are refreshing, but when 
depositing a dot we have to know where in 
the buffer we have space for a “new dot” 
(HL on stack). We also have a screen 
location pointer (DE) for the cursor and a 
counter (C) to determine the cursor's 
winking rate. If a routine like this is used as 
a subroutine, care should be taken to save 
everything on the stack before returning to 
the main program. 


Other Ideas 


Can a pair of digital to analog converters 
connected to a computer be used for appli- 
cations other than graphics? Absolutely! An 
obvious idea would be waveform generation, 
but how about musical instrument syn- 
thesis? One converter could be connected to 
a wide range voltage to frequency converter 
such as the Raytheon 4151 and the other 
converter could provide envelope informa- 
tion. Passive components could tailor the 
output of the 4151 to suit the instrument 
being synthesized. Just about any con- 
tinuous range phenomenon can be put under 
the control of the computer using a digital 


Listing 1: An Intel 8080 program to drive the Beer Budget Graphics system. 
This program uses inputs from an ASCII encoded keyboard to command 
various cursor movements and perform the utility functions of clearing the 
screen and entering data. The cursor is an extremely bright point whose 
coordinates are maintained in the D and E registers. Data is kept in locations 
300 to 6FF. 


Addr Hex Code Label Op Operands Commentary 
0200 31 FO ОЕ START LXI SP,FOOF Initialize stack pointer; 
0203 21 00 03 LXI Н,300 Initialize next new dot pointer 
0206 €5 PUSH H and push onto stack; 
0207 21 90 03 REFRESH LXI H,300 Set refresh pointer to start of buffer; 
020A 7Е MORE MOV A.M A := @HL [get horizontal coordinate] ; 
0208 32 05 80 5ТА OUTPUTX X coordinate := А [memory location is output! ; 
020Е 23 INX н HL := HL + 1 [point to the vertical coordinate] ; 
020Ғ 7Е моу Ам A := (HL [get vertical coordinate] ; 
0210 32 06 80 STA OUTPUTY Y coordinate := A [memory location is output] ; 
0213 23 INX H HL := HL + 1 [point to horizontal coordinate] ; 
0214 3E 07 MVI АЛ А := buffer page address limit; 
0216 BC CMP H 15 HL pair at end of buffer? 
*0217 C2 GA 02 JNZ MORE lf not then repeat the display loop; 
021A Ор DCR c C := C — 1 [decrement cursor counter] ; 
“0218 CA 77 02 JZ CURSOR 1 zero then output the cursor pattern; 
021E AF INPUT XOR A A:=0; 
021Ғ ЕВ ЕІ Enable interrupts from keyboard; 
0220 00 МОР Interrupt window to service keystroke; 
0221 F3 DI Disable interrupts from keyboard; 
0222 FE 00 СРІ 0 Was there any input? 
"0224 CA 07 02 JZ REFRESH If not then go refresh display again; 
0227 Еб 7Е АМ! 7F А := А & ТЕ (remove most significant bit with mask]; 
0229 FE 4C CPI 1’ Was it move cursor left? 
%0228 СА 4А 02 JZ LEFT Jf so then go move the cursor left; 
022Е FE 52 CPI ‘RS Was it move cursor right? 
"0230 CA ЯҒ 02 JZ RIGHT if so then go move the cursor right; 
0233 FE 55 CPI "Ut Was it move cursor up? 
“0235 СА 54 92 JZ UP {f so then go move the cursor up; 
0238 FE 44 СР! р“ Was И move cursor down? 
"023A CA 59 02 JZ DOWN If so then go move the cursor down; 
023D РЕ 2F CPI Ұй Was it a clear command? 
"023F СА БЕ 02 JZ CLEAR И so then go clear the display; 
0242 FE 2А CPI "t Was it a deposit dot command? 
*0244 CA 6E 02 JZ DEPOSIT Hf so then go deposit a dot; 
*0247 сз 07 02 JMP REFRESH Bad command, so back to refreshments; 
024A 14 LEFT INR D Move cursor left one space; 
024B 14 INR D [Second move, NOP if 8 bit DAC used] ; 
*024C сз 07 02 JMP REFRESH Refresh the display; 
024Е 15 RIGHT DCR D Move cursor right one space; 
0250 15 DCR D [Second move, NOP if 8 bit DAC used]; 
*0251 сз 07 02 JMP REFRESH Refresh the display; 
0254 ID UP DCR E Move cursor up one space; 
0255 1D DCR E [Second move, NOP if 8 bit DAC is used] ; 
*0256 сз 07 02 JMP REFRESH Refresh the display; 
0259 1c DOWN INR Е Move cursor down one space; 
025A 1C INR E [Second move, NOP if 8 bit DAC] ; 
“0258 сз 07 02 JMP REFRESH Refresh the display; 
025E 21 00 03 CLEAR LXI H,300 HL :7 starting address, refresh buffer; 
0261 3E FF AGAIN MVI A,FF A := null coordinate value, lower left; 
0263 77 MOV MA @HL := А [zap a buffer location) ; 
0264 23 ІМХ H HL := HL + 1 [point to next location] ; 
0265 3E 07 MVI A,07 А :7 page address of buffer limit; 
0267 BC CMP H Is HL at the limit? 
*0268 с? 61 02 JNZ AGAIN If not then continue zapping memory; 
*026B сз 00 02 ЈМР START When done, restart the program; 
026Е Е1 DEPOSIT РОР H Pull otd buffer location pointer; 
026F 72 MOV M,D @HL := horizontal cursor position; 
0270 23 (NX H HL := HL + Т [point to next coordinate in buffer] ; 
0271 73 MOV M,E @HL := vertical cursor position; 
0272 23 INX H HL := HL + 1 [point to next coordinate] ; 
0273 ЕБ PUSH H Push current buffer location pointer; 
"0274 сз 07 02 JMP REFRESH Refresh the display; 
0277 7A CURSOR MOV A.D А :7 horizontal position; 
0278 32 05 80 STA OUTPUTX X coordinate := А; 
027B 7B MOV А,Е А :7 vertical position; 
027C 32 06 80 STA OUTPUTY Y coordinate := A; 
027F ОЕ 08 MVI c8 Set cursor counter to 8; 
*0281 СЗ ТЕ 02 JMP INPUT Go get more inputs; 
Notes: 


All constants are hexadecimal; 

@HL in commentary indicates the contents of memory location pointed to by HL pair; 

*next to address indicates the instruction contains an address which must be recomputed 
if the program is relocated; 

'X' indicates ASCII character X; 

Note that 16 bit data format for the 8080 stores the low order byte in the lowest 
address, thus the hexadecimal value 8006 (for example) is seen in the listing as 
06 80. 

For 8 bit converters, the increment or decrement instructions at locations 024B, 0250, 
0255, and 025A must be replaced by NOP instructions. 


to analog converter. The Motorola applica- 
tion sheet for the MC1408 includes ideas 
such as programmable gain amplifiers, a 
programmable power supply, a program- 
mable constant current source, and others.B 
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There's 


another side 


of IMSAI 


you should know 


Sure you know our IMSAI 8080 
computer Its size, quality, 
performance and price set the 
industry standard for value. 
Theres another, equally important 
side of IMSAI — our broad and 
ever growing I/O product line. 
Right now IMSAI offers an array 
of sensibly priced, versatile, high- 
quality interfaces and peripherals 
that live up to the IMSAI 8080 for 
quality technical leadership, 

and value. 


IMSAI VIDEO DISPLAY. We 
call it the most powerful, flexible 
video display interface available. 
With up to 3 boards that fit into 
your IMSAI you can display color 
characters and color graphics. 
simultaneously. - Unlimited 
image control. - Large capacity 
display. - Eight colors; 7 half tones. 
- All cables included. - Full 
ASCII character set. - Character 
blink, reverse video, multiple 
cursor and double-width 
characters. 


IMSAI KEYBOARD. 53-key 
ASCII encoded keyboard with 
good touch quality and upper 
case alphanumeric keys that 


duplicate functions of the ASR-33. 


Supplied with commercial grade 
cabinet and cable. Interfaces to 
any 8-bit parallel port. 


IMSAI 44 COLUMN PRINTER. 


44 column dot matrix printer 
offering hard copy output at an 
affordable price. Interfaces to 
many computers using an 8-bit 
parallel output port. Simple 
programming and installation. 
Self-contained with case, cable, 
power supply timing, control and 
character generation included. 
Produces 75/lines/min.; double 


size characters software selectable. 


IMSAI VIDEO DISPLAY 
Assembled $1199.00/ Unassembled $699.00 


IMSAI MULTIPLE I/O BOARD 
Assembled $350.00/ Unassembled $195.00 


IMSAI MULTIPLE 10 BOARD. 
Simultaneous control of key- 
board, printer, tape cassette (Byte 
or Tarbell) and teletype (or CRT) 
bya single MIO board. Our 5-port, 
multiple I/O board combines the 
most commonly used I/O inter- 
faces including a cassette interface. 
faces including a cassette interface, 
two parallel I/O ports, one serial 
channel and one control port— 
all on one board! 


And many other IMSAI I/O 
interfaces to expand your system. 
Examples: 

IMSAI Programmable 
Parallel I/O board offering 6-ports 
for the ultimate in I/O flexibility 
and control. 


Assembled $549.00/ Unassembled $399.00 


IMSAI KEYBOARD 
Assembled $199.00 


IMSAI 2-Channel serial 
I/O board with 3 modes for total 
versatility in communications. 

IMSAI 4-Port Parallel 
I/O board with LEDs for visual 
observation of data flow. 

IMSAI Intelligent Bread- 
board for easier, more accurate 
circuit design and classroom 
instruction. 

IMSAI 4K RAM —the 
best price performance 4K RAM 
board on the market. 


Socket sets for all boards. 
Use for easier board maintenance. 


For commercial applica- 
tion— Our IMSAI floppy disc with 
disc operating system and 
extended BASIC. 


IMSAI PRINTER 


ALL these IMSAI prod- 
ucts available NOW at your IMSAI 
dealer or from the factory 

Yes, the other side of 
IMSAI has much to offer. Its a 
complete I/O line with products 
that match the IMSAI 8080. We 
offer a detailed, illustrated catalog 
describing the IMSAI 8080, its 
options, peripherals, software, 
prices and specifications. Send 
one dollar to cover handling. 
Write or call for name of the 
nearest dealer. 


Dealer inquiries invited. 


MSA 


IMS Associates, Inc. 
14680 Wicks Boulevard 
San Leandro, CA. 94577 
(415) 483-2093 

TWX: 910-366-7287 


Photo 1: With a high resolution display of 256 by 208 points, the author's 
display system becomes a programmable blackboard for numerous games and 
visual outputs. A relatively trivial game is the simulated tennis often seen in 
bars, restaurants and airport waiting lounges (to say nothing of mass 
produced special purpose home video game sets). The software required is 
relatively simple and the display has only three moving objects — the two 
paddles and the ball. As in all interactive games, some form of player input is 
required. This can typically be supplied by a variable resistance (as in a 
potentiometer, slide pot or joystick) and an analog to digital converter. 


Add This 
Graphics 
Display 

to Your System 
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Thomas R  Buschbach 
12310 Purcell Rd 
Manassas VA 22110 


Since one of the reasons I built a personal 
microprocessor was to play video games, | 
needed some type of high resolution graph- 
ics display capability. After examining the 
current unavailability of a low cost commer- 
cial product to perform this task, | decided 
to build my own unit, The main reason, 
besides cost, was that | wanted a 256 by 256 
dot matrix (as you'll see below, I actually 
got 256 by 208). Since my system already 
contained a television display generator 
board for character information, | decided 
to build a graphics display unit which would 
utilize existing synchronization, blanking, 
and timing pulses. For storage of the data to 
be displayed, | started with a standard 
programmable memory board populated 
with 8 К eight bit bytes of 500 ns access 
time 2102 integrated circuits. 

My design goals for this project were to: 


€ Utilize all possible circuitry existing on 
the television display interface board. 

@ Have the graphics display work in 
parallel with the existing alphanumeric 
character display. 

€ Have the ability to use the graphics 
display region of memory for ordinary 
programming purposes if the display is 
suppressed. 

@ Use direct memory access techniques 
(DMA) so that the graphics display 
data appears as ordinary program- 
mable random access memory as far as 
the computer is concerned. 


| was able to meet all these goals for a 
total cost of $25 in integrated circuits, above 
the cost of the existing display generator and 
memory boards of my system. If your 
system does not have an 8 K programmable 
memory board available, you will need to 
purchase one. Remember, when the graphics 
display is not in use, the memory can be 
utilized as if it were an ordinary program- 
mable memory region; so the investment will 
also pay for itself in terms of raw memory 
power for your non graphics applications. 

If your system does not have a television 
display generator board, the synchroniza- 
tion, blanking, and timing pulses can easily 
be generated using counters. | would suggest 
reading Don Lancaster's new book, 7V 
Typewriter Cookbook. Chapter 4 contains 


an explanation and schematics of the circuits 
to generate the required pulses. 

The graphics display unit functions as an 
interface between the processor, the 8K 
memory board, and the television display 
generator, to provide the graphics capability. 
A block diagram of this interface is shown in 
figure 1. The graphics display unit has two 
modes of operation, display mode and up- 
date mode. In display mode, the unit 
cyclically accesses all addresses of the pro- 
grammable memory board using direct 
memory access, then converts the output 
from parallel to serial, sending it to the 
television display generator to be combined 
with any alphanumeric information and dis- 
played on the monitor or TV set. Since this 
operation must occur in parallel with normal 
processor functions, the address bus of the 
memory must be isolated from the pro- 
cessor’s address bus. The output data from 
the memory must also be isolated from the 
system’s data buses. In the update made, the 
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Photo 2: With a high resolution display, games need not be kept simple. Here 
is an example of a much more complex game display on the author’s system, 
again modeled after the commercial games often found in entertainment 
centers. To set up such a display typically requires software to create the 
background maze, keep track of all the movable pieces, and of course 
program the logic of the game simulation. 


PROCESSOR DATA INPUT BUS 


GATED WRITE STROBE 


PROCESSOR ACCESS GRANT 


GRAPHICS 


Figure 1: System Diagram. The graphics display unit interfaces to three elements of an existing 
system: The processor and its buses, the television display generator, and the 8 K programmable 
random access memory. The graphics display unit is normally in the display mode, where it 
continually displays data contained in the programmable memory module. If the processor 
references a location within the programmable memory’s address space, the graphics display 
unit enters the update mode either immediately or during the next vertical blanking pulse 
depending upon the setting of a switch. In the update mode, the processor commands the 
memory and the display looks at random output bits, which are of course ignored during the 


blanking period. 
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VERTICAL BLANKING FROM 


TV DISPLAY GENERATOR 


WRITE STROBE 
FROM PROCESSOR 


WAIT REQUEST 


о 
PROCESSOR 


processor is given control of the memory’s 
address bus and allowed to read or write 
data. The update mode should only be 
entered while the television display gener- 
ator is sending a vertical blanking pulse. This 
prevents the update from causing a spurious 
blip on the screen. However the penalty for 
observing this requirement is that the pro- 
cessor may have to wait for nearly a com- 
plete television frame time, about 13.5 ms 
maximum in the author’s system, A memory 
wait this long is impossible for processors 
such as the 6800 which do not have a 
memory ready mechanism, in which case an 
alternate mechanism such as an input port 
bit line could be used. 

A more detailed block diagram of the 
functions of the graphics display unit is 
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shown in figure 2. This design is composed 
of three functionally distinct areas: the three 
state buffers and their control logic, the 
counters, and the shift registers. The block 
diagram and details of this article assume 
also that the processor has a split “іп” and 
“ош” memory data bus as is utilized in the 
Altair 8800 or Digital Group designs. 

The state of the buffers is determined by 
the mode in which the graphics display unit 
is operating. In the display mode, the buffer, 
block (2) in the figure, allows signals to pass 
while buffers of blocks (1) and (3) must be 
in a high impedance state. This gives the 
graphics display unit’s counters control over 
the programmable memory’s address bus and 
blocks the output data from entering the 
processor’s data input bus. Їп the update 
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Figure 2: Detail Block Diagram. As in all “top down" system designs, the design progresses by filling in more and more detail. 
Here is a block diagram of the actual graphics display unit. This figure shows a detailed functional arrangement of the interface 
as constructed by the author. In the display mode, the graphics display unit continually cycles through all addresses in the 
programmable memory, outputting serial video levels to the television display generator, for mixing with existing character 
graphics information. In the update mode, the graphics display unit allows the microprocessor to control the programmable 
memory unit's address and data lines for normal access. The mode switching is automatic based upon whether or not the address 
sent by the processor is within the display $ address space. 
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mode, the buffers (1) and (3) allow signals 
to pass while the buffer (2) is in a high 
impedance state. This gives the processor 
control of the programmable memory’s ad- 
dress bus and allows memory to be con- 
nected to the processor’s data input and 
address buses. The gated write strobe pulse is 
also enabled in this mode. Note that the 
processor is the only source of data written 
to the memory, so there is no switching of 
the processor data output bus which drives 
the inputs of the memory banks. 

The mode control logic determines the 
proper mode of operation at any given time. 
It does this by monitoring the three most 
significant bits of the processor’s address bus 
to determine if it is referencing a location in 
the programmable memory region assigned 
to the graphics display. If it is not refer- 
encing graphics memory, then the graphics 
display unit will remain in the display mode. 
If the processor does reference a location in 
the graphics display region of address space, 
then the television display generator is 
checked to see if it is generating a vertical 
blanking pulse. If it is, and if the graphics 
display is set (using S1) to prevent visual 
noise ("sparkle") caused by updates, then 
the display is changed into the update mode 
and the memory access takes place as if the 
processor were addressing an ordinary loca- 
tion. However if the television display gener- 
ator is not in the vertical blanking period, 
and the graphics display is set via S1 to avoid 
arbitrary data during updates, then the 
processor is placed in a wait state until the 
next vertical blanking pulse is initiated, at 
which time the update mode is again 
entered. Note that this feature will only 
work with processors incorporating a mem- 
ory ready line for slow response memories; 
an alternate mode of operation in which 
updating has priority over display must be 
used for processors which cannot wait. 

The counters control the memory address 
bus during display operations, continually 
cycling through all locations with a full cycle 
taking 1/60th of a second (16.67 ms). These 
counters must be in synchronization with 
the existing counters in the television display 
generator. Most such television display 
generators contain two sets of counters. One 
set counts the character's position on the 
line. Each character is typically 8 bits wide, 
and there are typically 32 characters per line 
for a total of 256 dots per horizontal line. 
The other set of counters counts the number 
of horizontal lines which have been generated 
(TV scan lines, not character lines). In a 
typical television display without interlace 
there would be a maximum of 256 horizon- 
tal lines. On the television display generator 


Y = AXSINCX) 


Photo 3: Not all outputs need be game oriented of course. Here is an example 
of a graphic output which could easily be used for engineering purposes: 
plotting the two dimensional behavior for some function. Here the author has 
calculated a sine wave using a BASIC package and appended various character 
graphics captions. The basic X-Y axes and the character graphics can be 
generated typically by a table looRup with some calculation; the actual points 
of the curve can be generated directly from the function calculation by 
calculating integer positions. In either case, to conveniently program the 
display, a set of bit manipulation subroutines is required to read and write 
individual bits, given the coordinates within the matrix. 


board, there are pulses which clear these 
counters. These pulses should be used to 
clear the corresponding set of counters in 
the graphics display unit. The pulse which 
clears the line counters has an added signifi- 
cance: |t also determines how many of the 
possible 256 horizontal lines will actually be 
visible on the screen. Due to overscan on a 
conventional television screen, the actual 
number of lines visible is never 256. A 
typical number of visible lines for a tele- 
vision display generator such as my Digital 
Group product is 208. This means that the 
visible display is actually a 256 by 208 dot 
matrix. Note that this leaves 1536 bytes of 
the 8192 bytes in the 8 K byte memory 
module free for normal programming pur- 
poses (see figure 4). To determine how many 
lines your particular television display gener- 
ator displays, examine the logic which con- 
trols the clearing of the line counters and 
determine the value of the counters just 
prior to the clearing pulse. 

The shift registers convert the parallel 
data from the programmable memory into a 
time varying string of video levels in 
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Schematic Diagram. Taking this “top down” hardware system design one level further for a specitic case yields this 


Figure 3: 


agram of the interface as implemented for a Digital Group system and Digital Group television display generator. 
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ry and wiring. The memory matrix is 


it 


Each element of the block diagram in figure 2 is shown here in the form of actual circui 


shown as a generalized box with 8 bank selection inputs for each 1 K bank within the module. 
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synchronization with the video level infor- 
mation generated by the existing television 
display generator. Two shift registers are 
required so that one may be loading data 
while the other is shifting data out. To 
insure that the graphics display unit video 
information is in synchronization with the 
video of the television display generator, the 
clock pulse for the television display gener- 
ator’s shift register should be used for the 
graphics display generator’s shift registers. 
The load or shift input to the graphics 
display unit shift registers is controlled by 
the least significant address bit generated by 
the graphics display’s counters. This bit 
changes state each time that a new byte is 
accessed їп memory. The timing here is 
critical. The shift register which was loading 
data must disable its parallel inputs before 
the change in the address lines affects the 
data output from the memory. For the 
2102-1 integrated circuits this time is a 
minimum of 50 ns. This shift register must 
also change from the loading state to the 
shifting state prior to the next clock pulse 
from the television display generator. This 
may require slightly delaying the clock pulse 
from the TV display generator. In my 
system, it required approximately 20 ns de- 
lay in the clock line, provided by using a pair 
of inverters in series. A data selector is used 


Table 1: Integrated Circuit Power List. 


Device 


8T97 
8197 
8T97 
8797 
8T97 
8197 
8T97 
74193 
74193 
74193 
74193 
7442 
74125 
74125 
74165 
74165 
74157 
7404 
7437 
7404 
7410 


+5 У 


to pick the output from the shift register 
which is currently shifting data. 

Figure 3 shows the implementation of 
this system for a Digital Group 8080A 
system, using the block diagram of figure 2 
to guide the detailed design. In my descrip- 
tion which follows, no attempt is made to 
explain the schematic in detail. Instead, the 
various components are related to the func- 
tional blocks of figure 2. 

ІСІ, ІСЗ and part of [C5 make up the 
buffer, block (1) in figure 2, which isolates 
the processor’s address bus from the mem- 
ory in the display mode. ІС2, ІС4, and part 
of ICS form the buffer, block (2) of figure 2, 
which isolates the graphics display unit 
counters from the memory in the update 
mode. IC6 and ІС? form the buffer, block 
(3) of figure 2, which isolates the processor’s 
data input bus from the memory in the 
display mode. (The processor’s data output 
bus is always connected to the input side of 
the memory, since it is the only source of 
data written in the memory.) IC13 and ІСІ4 
buffer the output from the memory circuits 
to provide the required output drive current. 

IC8 and ІС9 are the character counters. 
Note that the three least significant output 
bits of IC8 are left unconnected. This in 
effect divides the output by 8. Since each 
byte from the memory contains 8 bits of 


Hex Split Octal Hex Split Octal 
> 
5. | 2000 040/000------------------- 201Е 040/037 
әс 
a Ё 2020 040/040- ----------------- 203Ғ 040/077 
as e 
2 ° 
> ° 
39Е0 071/340- ----------------- 39FF 071/377 
эз > 39A0 072/000 — ———— ——— S 
ae ; 
HE ( 
“--------- -- 3FFF 077/377 
GND Programming Note: Addresses evenly divisible by hexadecimal 20 (decima! 32) in this 


address space allocation are the beginnings of a 256 bit (32 byte) raster scan line. 


picture byte is given by: 
ROTFAC := X & 7; 


hexadecimal 80 value.) 


МЈ МІОМІ E Со со о мМ со C0 CO 00 09 00 00 соо со CO CO 
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Using SHL(1,J) and SHR(I,J) to indicate the 16 bit left and right shift operations on І, 
by J positions, then given 16 bit integer coordinates X (horizontal coordinate from 
upper left) and Y (vertical coordinate from upper left down), the byte address offset of 
the required bit within the displayed memory region is: 

AB := SHL(Y, 5) + SHR(X,3) ; 

Similarly, the rotation factor required to place a mask bit opposite the desired bit of a 


(It is assumed that an 8 bit right rotate is used and the mask starts out with a 


Figure 4: Memory address space allocations for the graphics display. This 
figure charts the specific hexadecimal and split octal address locations for the 
208 lines and free area in the author's system. Each line is represented by 32 
eight bit bytes. Each byte specifies 8 consecutive dots on the screen, one for 
each bit. The zone al the end of the map contains the invisible section of the 
6 K region devoted to this memory and display subsystem. 


information, a new byte is required only 
after 8 bits are displayed. This assumes that 
a count pulse is received for each bit 
displayed. ІС10 and ІСІТ are the line coun- 
ters. They count the number of scan lines 
which have been displayed. 

ІСІ5 and ІСІ6 are the two shift registers. 
Note that the clock input to these integrated 
circuits passes through two inverters in 
series. This provides the 20 ns delay required 
to allow the shift registers to change state 
from the load mode to the shift enabled 
mode. The output of the shift register which 
is shifting out data is selected by 1C17 to be 
sent through a NAND gate to the television 
display generator where it is combined with 
the existing video display signal. Switch S2, 
also connected to the NAND gate 1C21b, 
provides the capability to blank the video 
display from the screen. If this switch is 
omitted and the wire from ІС21 pins 3 and 4 
connected to one bit of an output port, 
programmable blanking of the graphics can 
be achieved. 

1С12 is a BCD to decimal converter which 
is used to select one of the eight program- 
mable random access memory banks on the 
8 К memory card. This integrated circuit 
converts the contents of address bits A10 to 
A12 into a bank enable signal which drives 
the eight 2102s of each 1 K bank within the 
memory card. 

IC18, ІС19, ІС20 and ІС21 provide the 
mode control logic. The board address selec- 
tion jumpers are connected to locate the 
memory at the desired position in address 
space. The jumpers as shown locate the 
visible portion of memory in addresses 8192 
to 16,383 (hexadecimal 2000 to 3FFF, split 
octal 040/000 to 077/377). Note that in the 
case of a television display generator with 
less than 256 lines visible, the upper portion 
of the memory range is available for program 
storage. In the 208 line case of my system, 
the 1536 invisible bytes are located at 
hexadecimal addresses 3A00 to 3FFF, split 
octal addresses 072/000 to 077/377. Figure 
4 shows the layout of memory and its 
relationship to the displayed data. The low 
addresses in memory define the top of the 
image; the high addresses in memory define 
the lower portion of the image. 

Since the processor is granted access to 
the memory only during the vertical blank- 
ing pulses in the scheme just described, 
programs which have critical timing may not 
work properly. For example, software for a 
cassette interface has timing requirements 
asynchronous to the video display and 
would not work properly if referencing data 
in the display region of memory. Switch S1 
in figure 3 is provided to allow the processor 
access to memory at any time, without 


waiting. Thus when loading the display 
memory from a cassette tape, the conflict 
between the graphics display wait time and 
the needs of time critical software is resolved 
(at the expense of "sparkle" in the display 
during the loading). For processors which 
cannot wait for slow memory, 51 should be 
eliminated and the enable input, IC19 pin 5, 
should be grounded. 


In making the connections from the 
graphics display to the television display 
generator and memory board, make all wires 
as short as possible, certainly not longer than 
10 to 11 inches (25 to 28 cm). Depending 
upon the existing loads on the signals you 
are tapping, buffers may be required to drive 
the lines. The power bus should be heavily 
bypassed with .01uF capacitors from +5 V 
to ground. 


In Conclusion 


This graphics display generator can be 
built very inexpensively, taking advantage of 
existing circuitry in the form of memory 
modules and a television display generator. 
When you've got it up and running, the 
world of visual imagery will be available to 
you on your television output, as is demon- 
strated by the examples seen in photos 1 
through 3.m 
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ANY WAY YOU WANT IT! 


5 X 7 IMPACT DOT MATRIX * 75 LINES PER MINUTE 
40 COLUMNS e 12 CHARACTERS PER INCH 
6 LINES PER INCH е ORDINARY ROLL PAPER 
CHOOSE FROM THESE THREE ASSEMBLED AND 
TESTED MODELS COMPLETE WITH CASEWORK 


e LCP-40 е Parallel I/F without character generator 
for special software fonts ............. 

e MP-40 e Parallel I/F with 64 character 
АСС ШШ БӨ 254% сек a ки ehe 
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А Тір for Using Wiring Pencils 


R W Burhans 

Avionics Engineering Center 
Ohio University 

Athens OH 45701 


One of the problems in using the Vec- 
tor or other brands of ‘‘wiring pencils ” 
is the poor visibility of the fine #36 wire 
viewed against the typical background of 
Vector Blue circuit board material. Older 
types of light green epoxy fiberglass boards 
give somewhat better contrast and the lower 
quality epoxy paper board is very easy on 
the eyes due to its light color. Of the various 
colors available, the red wire has the best 
contrast with respect to the newer blue 
board materials, but even this is sometimes 
not good enough. The assembly of proto- 
type hardware with this technique can be 
greatly improved by laying down a layer of 
yellow insulating tape where the pencil wrap 
wires are to run. We have used 3M brand 
yellow coil insulating tape. This is almost 
exactly. like 0.25 inch (0.635 cm) wide tape 
recorder splicing tape. The yellow tape is 
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placed on the circuit board after the com- 
mon grounds and positive power buses are 
hard wired to the socket pins using bus strips 
or heavy gauge wire. Then the task of trying 
to see the fine wrap wires becomes much 
easier for the remainder of the assembly. An 
example showing the underside wiring of an 
Omega-VLF receiver interface for use with a 
JOLT microprocessor is shown in photo 1. 

[More about the Omega microprocessor in- 
terfaces will appear in a future issue of 
BYTE.] Small strips of the yellow insulating 
tape are cut and pasted to help hold the 
wires in place for semipermanent prototype 
circuits. In general we like to use hard 
soldered connections for prototype work 
where the microprocessor interface hardware 
is used in mobile, marine, or airborne equip- 
ment. In such applications, the effects of 
vibration are a major reliability considera- 
tion, hence the need of solder as a “glue” for 
the wiring. A combination of top of board 
jumper wiring and the Vector wire wrap and 
solder technique results in less eye strain 
during assembly when the yellow insulating 
tape is used to improve the wire visibility.m 
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Photo 1: Using the data of listing 2 with the program of listing 1, this picture of a famous space craft can be placed ona TV 
screen using the Southwest Technical Products GT-6144 display. The actual picture is created from three data table segments 
which define the Enterprise, the Earth and the background of "stars." 


An Enterprising Display Device 


Joe Deres 


Southwest Technical Products Corp 
219 W Rhapsody 
San Antonio TX 78216 


Many people find games one of the most 
interesting applications of a computer sys- 
tem. These range from simple games such as 
Tic Tac Toe, Blackjack and Ping Pong to 
very complicated games such as Space War. 
All of these have one thing in common; they 
are much more fun when played using a 
video graphics display. With such terminals 
you can provide instant response and pro- 
vide a pictorial playing area that cannot be 
duplicated on any type printing terminal. 
Can you imagine attempting to play an 
elaborate game on a Teletype machine? 
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Unfortunately, the typical high resolution 
graphics display normally costs thousands of 
dollars and is completely beyond the budget 
of the average person. 

The GT-6144 is our answer to this 
dilemma. By settling for a bit less resolution 
than is available in expensive graphics termi- 
nals we can generate graphic displays on any 
monitor (or a standard TV set to which a 
video input has been added). 

In this design, the display screen is 
divided into an array of cells 64 positions 
wide by 96 positions high. Each cell is 
individually addressable and may be selec- 
tively turned on or off by programmed 
commands from the parallel interface to 
your computer. With a little imaginative 
programming (and lots of memory) fixed or 


moving images may be displayed оп the 
screen for added enhancement to game 
programs. Photo 1 shows Star Trek’s star 
ship, the “USS Enterprise,” generated with 
the GT-6144 by running the program of 
listing 1 using data of listing 2 in an SWTPC 
6800 Computer System. It takes only 2 us 
to load a single cell of the display memory; 
much faster than most contemporary per- 
sonal computers can generate the infor- 
mation. The system features a power up 
screen blanking circuit which in addition 
may be enabled, or disabled at any time 
through program commands from the com- 
puter system or hardwired switches. ln 
addition, an image reversing feature allows 
you to select between white on black or 
black on white images by a simple one word 
command generated by your computer's 
program. The system will operate on either 
50 Hz or 60 Hz power lines with American 
standard 525 line or European standard 625 
line television sets or video monitors. 

The GT-6144 design incorporates a 6,144 
bit static programmable memory which 
eliminates the requirement that it be used 
with a specific computer system. The termi- 
nal will operate with any computer system 
whose parallel TTL level interface outputs 
an 8 bit data word and data ready strobe. 
The hookup problem then reduces to 
making sure that each bit line at the inter- 
face runs to the corresponding bit at the 
input to the GT-6144. 

The unit is available as a kit which is 
complete less the chassis and does not 
include the required video monitor or modi- 
fied television set. Instructions for the 
addition of a video input jack to a typical 
television are included with the kit, and a 
switch installed on the back of the TV set 
will allow one to select between terminal 
and normal television operation. You may 
use the same television set or video monitor 
used by the CT-1024 terminal system. In 
fact, control commands from your computer 
allow you to display graphic, CT-1024 alpha- 
numeric, or even a combination of the two, 
all on the same display device. The mixing of 
graphic and alphanumeric video is engi- 
neered to work with an SWTPC CT-1024 
terminal. The video from other alpha- 


Listing 1: A GT-6144 Demonstration Program. This Motorola 6800 program, 
written to illustrate the operation of the GT-6144, contains routines to erase 
the screen, to write a pattern using a table of commands, and to select various 
options under control of a simple interpreter driven by the terminal 
keyboard. The routine is shown in assembly language format, with an origin 
at location 0000. This program must be run in programmable memory 
without write protection since several data items are located within the 
program text. Relocation of the program at arbitrary addresses other than its 
present page 0 origin will in general require modifications of symbolic code 
and reassembly to eliminate direct addressing at several points. There are 
several gaps in the addressing sequence used, reflecting the fact that the 
program was hand assembled. The data used to generate the picture seen in 
photo 1 is summarized in listing 2. 


Address Hex Code Label Ор Operand Commentary 


* This program, by Joe Deres, is designed to transfer 
* a data table of GT-6144 commands to the display. 
* The main entry pcint is at location ENTER, address 0016 


0000 00 00 START RMB 2 Pointer to data; 

0002 00 00 RMB 2 

0004 80 0С РІАЗ RMB 2 Pointer to PIA address of GT-6144; 
00 05 PIA3L EQu PIA3+1 


* The following subroutine sends the contents of accumulator A 
* to the GT-6144 and generates the active low ''data ready" 
strobe at the peripheral control pin of the PIA. 
0006 FE 00 04 OUTGR LDX PIAS 


0009 А7 00 5ТАА ох PlA3[data] := A [send data to GT-6144] ; 
000B C6 37 LDAB #$37 

0000 Е? 01 5ТАВ 1,Х PIA3[control] := code for low strobe: 
OOOF Е6 00 LDAB 0,X B := PlA3(data] [dummy op for timing] ; 
0011 C6 3F LDAB #$3F 

0013 Е? 01 STAB 1X PlA3Ícontrol] := code for high strobe; 
0015 39 RTS 


* The following is the initialization sequence for the program, 
* and the subroutine calls which invoke the picture generation; 
* The program is entered by calling ENTER with a JSR; 


0016 86 3C ENTER ШАА  s$3C 

0018 B7 80 07 STAA $8007 Disable control interface echo option; 

001B FE 00 04 LDX PIAS X := PIAS address pointer; 

001Е С6 РЕ LDAB #$ЕЕ 

0020 Е? 00 5ТАВ о,х PIA3{direction) := code for output ай bits; 

0022 C6 3F LDAB =$3Р 

0024 E7 01 STAB 1X PIA3[control] := code for high strobe, 
* and point to data register; 

0026 BD 00 A2 JSR ERASE clear the screen with subroutine; 

0029 7E 00 DO JMP SHOW fill screen with USS Enterprise or other 
М suitable data table; 


* The following subroutine, with entry at PUTGRPHX, is used to run 
* through a data table stored beginning at the address in START; 
0030 FE 00 00 NXTDATA LOX START 


0033 08 INX START := START + 1 (16 bits precision] ; 
0034 FF 00 00 STX START 

0037 FE 00 00 PUTGRPHX LDX START 

003A А6 00 LDAA ОХ if @START = FF [leave when data = ЕР]; 
003С 81 FF CMPA  sS$FF 

ООЗЕ 27 16 ВЕО ЕМОРОТ then go to ENDPUT; 

0040 8B 00 DISP1 ADDA #0 caution: program modifies immediate byte! 
0042 BD 00 06 NEWXSPOT JSR OUTGR 

0045 FE 00 00 LDX START 

0048 08 INX START := START + 1; 

0049 FF 00 00 STX START 

004C A6 00 LDAA 0,Х 

004E 81 РЕ СМРА #ФЕЕ if @START = FE then go to NXTDATA 
0050 27 ОЕ BEQ NXTDATA [treat as horizontal position if FE); 
0052 8B 00 DISP2 ADDA 20 caution: program modifies immediate byte! 
0054 20 ЕС BRA NEWXSPOT 

0056 39 ENDPUT RTS return to caller; 


* The following DISPLAY routine is used to set up the PUTGRPHX 
* routine, by modifying two bytes of code and setting up the 
initial pointer value in START at location 0000; 


0057 8B 40 DISPLAY ADDA z$40 [A is defined prior to entry] ; 

0059 В7 00 41 5ТАА DISP1+1 {DISP1+1} := #$40+ A; 

005С 17 ТВА [В is defined prior to entry] ; 

005D 8B 80 ADDA 4580 

005Ғ 87 00 53 STAA 015Р2+1 (DISP2+1) :- =$80 + B; 

0062 ЕЕ 00 00 STX START START :- X [X is defined prior to entry] ; 
0065 BD 00 37 JSR PUTGRPHX call graphics put routine; 

0068 39 RTS return to caller; 


* DELAY is a routine to generate a delay in processing, 
the parameter (approximately calibrated in seconds) is passed 
in the В accumulator; routine uses A and X; 


* 


0070 86 00 DELAY LDAA 20 A := 0 [outer loop count); 

0072 СЕ 00 00 NEWINNER LDX #0 X := 0 [inner loop count (time calibration)] ; 
0075 08 DELLOOP INX X= X41; 

0076 8C FF FF CPX 4$F FFF if X = ЕЕЕЕ 

0079 27 02 ВЕО OUTER then go to OUTER loop check; 

0078 20 F8 BRA DELLOOP else reiterate inner loop; 

007D 4C OUTER INCA А=А+1; 

007Е 11 СВА if A=B 

007Ғ 27 02 вға DELAYDON then go to DELAYDON; 

0081 20 EF BRA NEWINNER else go to NEWINNER [to start new inner loop]; 
0083 39 DELAYDON RTS return to caller; 


* The ERASE subroutine in locations 00А0 to ООСС is 

* used to clear the GT-6144 screen prior to establishing 
a new picture; it does this by addressing each 

display location in turn and setting a null state; 
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Listing 1, continued: 


Address 


00A0 
00A1 
00A2 
00А4 
00A6 
00A8 
00AA 
00AD 
O0AF 
O0B1 
00B3 
0085 
0088 
008B 
O0BD 
ООВЕ 
00С1 
00С4 
00С6 
00С8 
00СА 
oocc 


0100 


Hex Code 


BO 00 06 


BD 00 06 
7С 00 А1 


7С 00 AG 


BD El АС 


8D 00 06 


МХТОАТА 
PUTGRPHX 
DISP1 
NEWXSPOT 
DISP2 
ENDPUT 
DISPLAY 
DELAY 
NEWINNER 
DELLOOP 
OUTER 
DELAYDON 
HPOS 


Label Op Operand Commentary 

HPOS RMB 1 horizontal position data byte; 

VPOS RMB 1 vertical position data byte; 

ERASE LDAA  HPOS [entry point, outer loop for horizontal position] ; 
CMPA #$40 if HPOS = $40 [is it end of outer loop] ? 
ВЕС OUT then go to OUT [erasure is done] ; 
NOP [two do nothing NOPs] ; 
JSR OUTGR define horizontal coordinate; 

ERASEV LDAA  VPOS [inner loop for vertical position] ; 
CMPA #$60 if VPOS = $60 [is it end of inner loop] ? 
ВЕО SPEC then go to SPEC [and restart inner loop] ; 
ADDA #%80 convert coordinate to vertical command; 
JSR OUTGR define vertical coordinate and value; 
INC VPOS VPOS := VPOS + 1; 
BRA ERASEV reiterate inner loop; 

SPEC LDAA #$00 
STAA $A1 VPOS := 0; 
INC HPOS HPOS :- HPOS * 1; 
BRA ERASE reiterate outer loop; 

OUT LDAA #$00 
STAA НРО5 HPOS := 0; 
STAA VPOS VPOS := 0; 
RTS return to caller; 


* The SHOW routine is used to define the parameters of DISPLAY, 
* pointing to the Enterprise screen location and its data table, 
* then to call DISPLAY; since the vertical and horizontal 
* positions are parameters, the picture can be located at arbitrary 
* places within the display area of the GT-6144; 

Ow LDAA #805 


A. 0 locate Enterprise Б cells across, 
LDAB #$%00 and 13 cells down; 
LDX 4$200 point to Enterprise pattern data; 
JSR DISPLAY call DISPLAY to draw the Enterprise; 
LDAA #$1B locate planet Earth 27 celis across, 
LDAB #$40 and 64 cells down; 
LDX #$400 point to Earth pattern data; 
JSR DISPLAY call DISPLAY to flash the Earth; 
LDAB #$0A set approximately 10 second delay parameter; 
JSR DELAY 
LDAA #$00 locate random "'star'' data 0 cells across, 
LDAB #$00 and 0 cells down; 
LOX #$500 point to star pattern data; 
JSR DISPLAY call DISPLAY to draw in the stars; 
JMP OPTFUNC go to OPTFUNC [to perform optional functions] ; 


* The OPTFUNC routine is reached after the display is set up 
* оп the screen and is used to interpret several commands 
from the terminal keyboard in order to toggle some of the 
* options of the display unit; 
OPTFUNC JSR INEEE 


call INEEE (MIKBUG subroutine} to get 
а single character of input in A; 

* What follows is a simple series of tests to identify one of 

* eight commands selected by ASCII characters '1' through '7'; 


CMPA '1' ifA=‘1' 

BEG ONE then go to ONE; 
СМРА 7 if A= 2 

BEQ TWO then go to TWO; 
CMPA  '3 ЇҒА = '3' 

ВЕС THREE then go to THREE; 
CMPA LH ifA= '4' 

BEO FOUR then go to FOUR; 
CMPA  '5' if A= ‘5° 

BEQ FIVE then go to FIVE; 
CMPA %6 if A= ‘6 

BEQ SIX then go to SIX; 
CMPA 7 ТА ='7' 

ВЕО SEVEN then go to SEVEN; 
CMPA '8 if A= ‘8° 

BEQ EIGHT then go to EIGHT; 
BRA OPTFUNC try again, over and over forever; 


* Each individual command is implemented by defining a constant 
* in the A accumulator, then jumping to EXECUTE in order to call 
* OUTGR and modif y the state of the GT-6144; 


ONE LDAA %%Е0 ONE: Set normal screen mode; 
BRA EXECUTE 

TWO LDAA #$Е1 TWO: Enable CT-1024; display; 
BRA EXECUTE 

THREE LDAA #$Е2 THREE: Disable graphics display; 
BRA EXECUTE 

FOUR LDAA #$ЕЗ FOUR: Unused bit pattern; 
BRA EXECUTE 

FIVE LDAA #$Е4 FIVE: Set inverted screen mode; 
BRA EXECUTE 

SIX LDAA #$Е5 SIX: Disable CT-1024; display; 
BRA EXECUTE 

SEVEN LDAA #SEG SEVEN: Enable graphics; 
BRA EXECUTE 

EIGHT LDAA #SE7 EIGHT: Unused bit pattern; 

EXECUTE JSR OUTGR call OUTGR to select option; 
BRA OPTFUNC reiterate forever; 


Graphics table pointer; 

8 bit output PI A port; 

Graphics output routine; 

Main entry of graphics demo program; 


Graphics put routine; 


Graphics put routine setup; 
Delay routine (gross calibration in seconds); 


ERASE horizontal position; 
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numeric terminals will not necessarily work 
with the GT-6144 since the unit was 
specifically designed to work with the sync 
signals of the CT-1024. Power requirements 
for the terminal are 5.0VDC @ 14A, 
—12 VDC @ 20 mA and 6 VAC @ 20 mA. 


Programming 


The display of the GT-6144 graphics 
display generator produces a matrix of 6144 
small rectangular cells formatted 64 across 
and 96 down. Each of these cells can be 
turned on or off at will. In order for the 
GT-6144 to do a particular function the data 
fed to it must be formatted correctly. Figure 
1 summarizes the formatting conventions. 
The coordinate of a particular location is 
referenced from the top left corner of the 
screen with the first square residing at 
location (0,0). When sending data to the 
GT-6144, the first parallel byte sent to the 
terminal must be the horizontal position 
coordinate. The actual position is deter- 
mined by the binary number in low order 
bits B5 to BO. When bit B6 is 0, a rectangle 
will be removed at the desired coordinates; 
when B6 is 1, a white rectangle will be 
generated. Bit 7 must always be O for the 
display to know that a horizontal position is 
being loaded. A О in bit B7 causes the data 
holding flip flops in the terminal to store the 
present data. 


The second byte from the computer 
contains the vertical coordinate. The loca- 
tion is contained in binary in bits B6 to BO 
of this second byte while bit 7 must equal 
al. 

When programming an image to appear 
on the screen there are two ways the 
characters can be Joaded. The method used 
depends on how your software is organized. 
One method is to just send out successive 
coordinates (H1, Ут), (H2, V2) etc, until all 
H, V locations are specified. With this 
method two bytes must be sent out for each 
character. 

Another method can be used that will 
result in saving time and memory space. In 
this method the horizontal position of a 
particular column is loaded only once into 


ERASE vertical position; 
Subroutine to clear the screen; 


Routine to sequence display of photo 1; 
Options selection interpreter (keyboard driven); 


EIGHT 
EXECUTE 


the terminal. The vertical coordinate of all 
other characters that have this same hori- 
zontal coordinate can then be loaded by 
themselves since the horizontal position is 
latched in the terminal's holding flip flops. 
This second method is used by the programs 
accompanying this article. 

Since there are 96 characters to be 
accessed in the vertical direction at least 
seven address lines must be used. Seven lines 
give the possibility of addressing 27 (128 


USS Enterprise data 0200 — 0364 


0200 00 0220 08 025А 13 0287 08 
0201 0А 022Е 04 0258 08 0288 0С 
0202 08 022Ғ 05 025С 0С 0289 13 
0203 0С 0230 ОҒ 0250 ОҒ 028А 19 
0204 ҒЕ 0231 10 025Е 17 028В 1Ғ 
0205 01 0232 ҒЕ 025Ғ 18 028С ҒЕ 
0206 0А 0233 0С 0260 19 0280 19 
0207 0С 0234 04 0261 1А 028Е 09 
0208 ҒЕ 0235 05 0262 1В 028F 0A 
0209 02 0236 OF 0263 FE 0290 OB 
020A ОА 0237 10 0264 14 0291 OD 
0208 OC 0238 FE 0265 08 0292 13 
020C FE 0239 OD 0266 0С 0293 19 
020D 03 023A 05 0267 10 0294 1F 
020E 09 023B OF 0268 16 0295 FE 
020Ғ OC 023C FE 0269 17 0296 1A 
0210 FE 023D OE 026A 18 0297 05 
0211 04 023Е 05 026В 19 0298 ОҒ 
0212 09 023Ғ ОЁ 026С 1А 0299 13 
0213 0С 0240 ҒЕ 026D iB 029A 1F 
0214 FE 0241 OF 026Е 1C 0298 FE 
0215 05 0242 06 026F FE 029C 1B 
0216 09 0243 00 0270 15 029D 03 
0217 OC 0244 FE 0271 08 029Е 04 
0218 ҒЕ 0245 10 0272 0С 029Ғ 06 
0219 06 0246 07 0273 11 02А0 07 
021А 08 0247 0С 0274 15 02А1 11 
021В 0С 0248 ҒЕ 0275 10 02А2 14 
021С ҒЕ 0249 11 0276 ҒЕ 02А3 19 
0210 07 024А 07 0277 16 02А4 1F 
021Е 08 024B ОС 0278 08 02А5 ҒЕ 
021Ғ 0С 024С 19 0279 0С 02А6 1С 
0220 ҒЕ 024D FE 027А 12 02А7 02 
0221 08 024Е 12 027В 14 02А8 08 
0222 08 024Ғ 08 027С 19 02А9 13 
0223 00 0250 0С 0270 1Е 02АА 14 
0224 ҒЕ 0251 00 027Е ҒЕ 02АВ 19 
0225 09 0252 16 027Ғ 17 02АС 1F 
0226 07 0253 17 0280 08 02AD FE 
0227 OE 0254 18 0281 OC Q2AE 10 
0228 FE 0255 19 0282 13 O2AF 02 
0229 0А 0256 1А 0283 19 0280 08 
022А 05 0257 1В 0284 1Е 0281 14 
0228 ОҒ 0258 1С 0285 ҒЕ 0282 19 
022С ҒЕ 0259 ҒЕ 0286 18 0283 1Е 


Planet data 0400 + O4EF 


0400 00 041Е 06 043С 09 045A ОВ 
0401 1A O41F FE 043D FE 045B OC 
0402 1D 0420 ОА 043E OF 045С OD 
0403 1F 0421 05 043F 02 045D OE 
0404 FE 0422 O6 0440 08 045Е OF 
0405 01 0423 07 0441 09 045Ғ 10 
0406 17 0424 FE 0442 0А 0460 11 
0407 FE 0425 OB 0443 OB 0461 12 
0408 02 0426 04 0444 OC 0462 13 
0409 13 0427 05 0445 0D 0463 14 
040A FE 0428 06 0446 OF 0464 15 
040B 03 0429 07 0447 10 0465 FE 
040С 10 042A 08 0448 FE 0466 12 
040D FE 042B FE 0449 10 0467 02 
040Е 04 042C OC 044A 09 0468 05 
040F OD 042D 04 044B OA 0469 07 
0410 FE 042E 05 044C ОВ 046A OB 
0411 05 042F 06 044D OC 0468 OC 
0412 0B 0430 07 044Е OD 046С OD 
0413 FE 0431 0А 044F OE 0460 OE 
0414 06 0432 FE 0450 OF 046Е OF 
0415 OA 0433 OD 0451 10 046Ғ 10 
0416 ҒЕ 0434 03 0452 11 0470 11 
0417 07 0435 06 0453 12 0471 12 
0418 08 0436 09 0454 13 0472 13 
0419 ҒЕ 0437 0A 0455 FE 0473 14 
041A 08 0438 FE 0456 11 0474 15 
0418 07 0439 OE 0457 02 0475 16 
041С FE 043A 07 0458 09 0476 17 
041D 09 043B 08 0459 0A 0477 FE 


Star data 0500 — 0534 


0500 01 0507 04 050Е FE 0515 14 
0501 2C 0508 FE 050F OD 0516 58 
0502 FE 0509 ОА 0510 30 0517 FE 
0503 02 050A 1E 0511 FE 0518 19 
0504 58 050B FE 0512 OF 0519 4C 
0505 FE 050C OC 0513 44 051A FE 
0506 05 0500 40 0514 ҒЕ 051B 1E 


decimal) locations giving us 32 extra unde- 
fined locations. These extras can be used as 
control commands for controlling blanking 
on and off, reverse screen, etc. The format 
for control commands for the GT-6144 
display generator is found in figure 2. 

When writing programs care should be 
taken to optimize them for speed and 
memory conservation. All of the above 
functions can also be under hardware 
control by using SPST push button switches. 


0284 FE 02Е1 24 0300 08 0339 01 
0285 1E 02Е2 02 Q30E 15 033A 02 
0286 02 02ЕЗ 08 ОЗОҒ 1A 0338 08 
0287 08 02Е4 09 0310 FE 033C FE 
0288 14 02Е5 OA 0311 2А 0330 33 
0289 1Е 02Е6 ОВ 0312 02 ОЗЗЕ 01 
02ВА ҒЕ 02Е7 0С 0313 08 033Ғ 02 
02BB 1F 02Е8 OD 0314 16 0340 08 
O2BC 02 02Е9 ОЕ 0315 17 0341 ҒЕ 
0280 08 02ЕА ОҒ 0316 18 0342 34 
02ВЕ 14 02ЕВ 10 0317 19 0343 01 
O2BF 1E O2EC 11 0318 1A 0344 02 
02С0 FE O2ED 12 0319 FE 0345 08 
02C1 20 O2EE 13 031A 2B 0346 FE 
02С2 02 02ЕҒ 14 031В 02 0347 35 
02С3 08 02Ғ0 15 031С 08 0348 01 
02С4 14 02Ғ1 10 0310 FE 0349 02 
02С5 1Е 02Ғ2 ҒЕ 031Е 2С 034А 08 
02С6 ҒЕ 02Е3 25 031Ғ 02 0348 08 
02С7 21 O2F4 02 0320 08 034С FE 
02С8 02 02Ғ5 08 0321 ҒЕ 0340 36 
02C9 08 02Ғ6 15 0322 20 034E 01 
02СА 09 02Ғ7 1D 0323 02 O34F 02 
02CB ОА 02Е8 FE 0324 08 0350 08 
02CC OB 02Ғ9 26 0325 ҒЕ 0351 ҒЕ 
02CD OC O2FA 02 0326 2E 0352 37 
O2CE OD O2FB 08 0327 02 0353 02 
Q2CF OE 02ҒС 15 0328 08 0354 08 
0200 ОҒ O2FD 1B 0329 FE 0355 FE 
02D! 10 O2FE FE 032A 2F 0356 38 
0202 11 02ЕҒ 27 0328 02 0357 02 
0203 12 0300 02 032C 08 0358 04 
0204 13 0301 08 0320 ҒЕ 0359 05 
0205 14 0302 15 032Е 30 035А 06 
0206 15 0303 1А 032Ғ 01 0358 07 
0207 1Е 0304 ҒЕ 0330 02 035С ҒЕ 
0208 ҒЕ 0305 28 0331 08 0350 39 
0209 22 0306 02 0332 ҒЕ 035Е 02 
02DA 02 0307 08 0333 31 O35F 03 
020В 1D 0308 15 0334 01 0360 FE 
020C FE 0309 1A 0335 02 0361 2A 
0200 23 030A FE 0336 08 0362 15 
02DE 02 0308 29 0337 FE 0363 FE 
020Ғ 1D 030C 02 0338 32 0364 FF 
02Е0 FE 

0478 13 0496 17 0484 1С 04D2 1F 
0479 04 0497 FE 0485 1D 04D3 FE 
047A 05 0498 15 0486 1E 0404 1В 
0478 06 0499 07 0487 1Ғ 0405 08 
047С 08 049A ОВ 0488 1F 0406 1Е 
0470 0С 0498 0С 0489 ҒЕ 0407 ҒЕ 
047Е 00 049С 00 О4ВА 18 0408 iC 
047Ғ ОЕ 0490 ОЕ 048В 05 0409 ОА 
0480 ОҒ 049Е 16 04ВС 19 04DA FE 
0481 10 049Ғ 18 04BD 1A 0408 10 
0482 11 04A0 1C O4BE 1B O4DC 0B 
0483 12 04А1 FE О4ВЕ 1C 0400 FE 
0484 13 04А2 16 04CO 10 O4DE 1E 
0485 17 04A3 03 04С1 1E O4DF OD 
0486 FE 04A4 18 04С2 1Ғ 04Е0 ҒЕ 
0487 14 04А5 19 04С3 1Ғ 04Е1 1F 
0488 02 04А6 1А 04С4 РЕ 04Е2 10 
0489 06 04А7 1B 04С5 19 04ЕЗ ҒЕ 
048А 07 04A8 1C 04C6 06 04Е4 20 
048B ОА 04A9 1D 04С7 1C O4E5 13 
048C OB 04AA 1E 04С8 1D O4E6 FE 
048D OC 04AB ТЕ 04С9 1E 04Е7 21 
048Е OD O4AC 1F О4СА 1F O4EB 17 
048F OE 04AD FE O4CB 1F 04Е9 FE 
0490 OF O4AE 17 04СС FE O4EA 22 
0491 10 ОДАР 04 04CD 1A O4EB 1A 
0492 11 0480 16 O4CE 07 O4EC 1D 
0493 12 0481 19 O4CF iD O4ED 1F 
0494 13 04B2 ТА 04DO 1E O4EE FE 
0495 14 0483 1B 0401 ТЕ O4EF FF 
051C 3A 0523 FE 0529 FE 025F 2A 
051D FE 0524 31 052A 35 0530 FE 
051Е 20 0525 0A 052B 1C 0531 ЗЕ 
051Ғ 06 0526 ҒЕ 052С ҒЕ 0532 42 
0520 ҒЕ 0527 34 0520 3B 0533 ҒЕ 
0521 26 0528 34 052Е 02 0534 ЕР 
0522 30 
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Listing 2: It takes data to 
produce a picture. Here is 
a listing of the data which 
is used by the demonstra- 
tion program of listing 1 
to produce the picture of 
the USS Enterprise. 


Notes on Construction 
of a GT-6144 


This article contains the 
complete schematic апа 
enough details for an indi- 
vidual to wire up a version of 
the display using parts ob- 
tained from surplus suppliers 
and hand wiring techniques 
such as wirewrap or point to 


point soldering. 
The GT-6144 graphics dis- 
play generator is also available 


from Southwest Technical 
Products Corp, 219 W Rhap- 
sody, San Antonio TX 78216, 
as a complete kit of parts 
including the circuit board. 
The price of this kit is $98.50 
postpaid in the United States. 


Photo 2: Here is a picture 
of the GT-6144 as, con- 
structed using the printed 
circuit board and parts 
supplied with the South- 
west Technical Products 
kit. The logic diagrams of 
figures 1 to 3 are complete 
and based upon the origi- 
nal blueprint supplied by 
the author. Home brewers 
can use the design infor- 
mation of this article to 
wire up the circuit de- 
scribed here, oras a starting 
point in designing a cus- 
tomized version. 


HORIZONTAL COMMAND FORMAT: 


INTERFACE BIT — 7 6 5 4 3 2 1 0 
HORIZONTAL POSITION H 
0<Н < 63 
БАТА BIT: 


BRIGHTEN ACELL 
ERASE ACELL 


FORMAT INDICATOR, VALUE 0 


VERTICAL COMMAND FORMAT: 
INTERFACE ВІТ — j-wt 5 gay з € 1 0 
EN VERTICAL POSITION V 


— — = 


lico c V Ж 


FORMAT INDICATOR, VALUE 1 


Figure 1: Data Formats for the Parallel Interface to the GT-6144. The 
GT-6144 has two data formats. The horizontal command format is used to 
set the sense of the data to be written and load a 6 bit integer horizontal 
coordinate. Once the horizontal coordinate has been set up, the vertical 
command format is used to pick a vertical line with a 7 bit integer less than 
decimal 95 in value, and write the data value (“on” or "off") selected with 
the horizontal command. 
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How It Works 


The entire screen of this video display 
has been arranged for 96 lines of 64 charac- 
ters per line. In addition to the 96 lines of 
video data the television or monitor also 
requires the terminal to generate vertical and 
horizontal sync pulses. The GT-6144 con- 
sists of two major sections. The timing 
sections (figure 3) generate the necessary 
sync pulses, while the memory section (fig- 
ures 4 and 5) takes care of storing the 
necessary information and recalling it while 
a frame is being generated. 

The timebase oscillator as indicated in 
the schematic is responsible for initiating the 
horizontal sync pulse and for starting the 
chain of events that will generate one line of 
video data to be displayed. The circuit itself 
is a phase locked loop employed as a 
frequency multiplier. А 555, ІСІ, is used as 
an astable voltage controlled oscillator. The 
2N5139 transistor Q3 and TIS58 field effect 
transistor Q1 along with capacitor C5 form a 
sample and hold circuit which feeds IC1’s 
voltage control input through the TIS58 
field effect transistor Q2. The sample and 
hold in this case is being used as a phase 
comparator providing an output voltage pro- 
portional to the phase difference of the 
60 Hz power line and the multiplied output 
frequency of the 555 oscillator IC1. The 


actual amount of frequency multiplication is 
equal to the amount of frequency division 
between the output of the oscillator IC1 and 
the 60 Hz input reference frequency. As you 
will see later the value of the frequency 
divider is 264 and since our reference is 
60 Hz so that: 
fo = (60 Hz)*(264) = 15,840 Hz 

which is very close to the horizontal oscilla- 
tor frequency of a standard television set. 

The output of ІСІ is fed via inverter 
ІС23с across a jumper to ІСІ? sections b 
and c, where among other things a 4 us 
horizontal sync pulse is generated. From 
here the pulse is routed to IC15b where it is 
ORed with the vertical sync pulse which will 
be described in detail later. 

The falling edge of this sync pulse at the 
output of IC17c triggers IC16a, a one shot 
which puts out a positive pulse on pin 4 
adjustable by potentiometer R20 from 10 to 
30 us in length. The delay pulse creates a lag 
between the start of a line and the beginning 
of data, thus giving an adjustable left margin. 
Pin 4 of 1C16a inhibits dot oscillator IC16b 
through AND-OR-INVERT gate of IC10a. 
Pin 13 of IC16a resets 7493 counters IC19 
and IC 13, the 16 bit counters which address 
one of the horizontal positions on a line. 
Since we are just starting a new line we must 
first clear the counter to prepare it for 
incoming data. At the end of a high to low 
transition of pin 4 of 1C16, the 7493 vertical 
position counter IC6 is incremented; and if 
there is a ripple carry, ІС? is incremented as 
well. IC6 and ІС? together keep track of the 
horizontal scan line presently in use. To- 
gether these two counters provide a unique 
binary code for each of the 96 * 2 = 192 
video scan lines generated by the GT-6144. 

Now for those of you who are familar 
with television circuits, you probably know 
that we need more like 264 lines and not 
192 for a complete frame. When a count of 
192 (the 193rd line) is reached, (C15a sends 
out a clock pulse to IC4a and to IC9c which 
resets the line counters. When ІС4а is 
clocked pin 6 goes low, giving a blanking 
pulse to prevent any video data from being 
transmitted from the GT-6144. When pin 6 
of IC4 is low, pin 5 is high and enables 
decoders ІСІТа and IC11b. When the line 
counters reach a count of 32, IC11a triggers 
and remains so for 8 lines until count 40 is 
reached. The low output on pin 6 during this 
time is the vertical sync pulse, which goes to 
IC15b as mentioned earlier. At count 72 
ICiib triggers clearing flip flop IC4a which 
unblanks the video and resets line counters 
IC6 and ІС? for the generation of another 
line of displayed data. The above circuitry 
gives us a total of 192 + 72 = 264 scan lines. 


INTERFACE BIT — 


CONTROL COMMAND FORMAT: 


7 6 5 4 3 2 1 0 
CONTROL 
N у шш йө Ne ишы 


SEE LIST 
BELOW 


“DON’T CARE" STATES, 
SHOWN AS ZEROS 


HIGH ORDER BITS 5, 6 AND 7 ARE SET 
TO ONES TO IDENTIFY COMMAND 


FORMAT. 
Control Hexadecimal 
Code Code Meaning 

0 EO Inverted Screen, After this command is received, the display 
will show black cells or characters on a white background. 

1 E1 Normal Screen. After this command is received, the display 
will show white cells or characters on a black background. 

2 E2 Disable Characters, Remove information generated by the 
CT-1024 inputs (if any) from the display. 

3 E3 Enable Characters. Allow information generated by the CT- 
1024 inputs (if any) to be merged in the display output. 

4 Е4 Enable Graphics. Allow information generated by the GT- 
6144 display circuitry to be merged into the video display 
output. 

5 E5 Disable Graphics. Remove information generated by the GT- 
6144 from the video display output. 

6 EG Unused, 

7 E7 Unused, 


Figure 2: Data Formats for the Control Commands. The unused states of the 
vertical command format described in figure 1 are used to perform control 
operations. The control format and operations are shown here. Note that in 
the program of listing 1, the contents of bits 3 and 4 are assigned zero value 
arbitrarily since they are "don't care" inputs in control commands. 


Now let's get back to the horizontal 
portion of the circuit again. We left off 
earlier by saying that one shot oscillator 
ІС1ба provided an adjustable delay between 
the horizontal sync pulse and the generation 
of data to provide a left margin. We also said 
that an astable oscillator IC16b which is 
inhibited during this delay phase via IC10a is 
the dot oscillator which actually clocks off 
the dots for each line of video which form 
the rectangle. To continue the account 
where we left off, potentiometer R19 sets 
the cycle time for this oscillator from 0.5 to 
1 us which in turn sets the horizontal width 
of the rectangles displayed. The “dot clock” 
output, however, is not the output of 1C16b 
but rather the output of the AND-OR- 
INVERT gate IC10a. Its output is normally 
high, but goes low for about 30 ns each time 
IC16b resets. The 30 ns pulse time is set by 
the propagation of IC16b and IC10a and is 
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Timing Logic. This figure shows the design of the video timing chain which governs the operation of the GT-6144. The 
diagram of the circuit has been partitioned into three figures for this article, with connections between figures indicated 


Figure 3 


/ 


origina 


. Power connections for the integrated circuits in figures 3, 4 and 5 


are listed in table 1, and the three jacks used for interconnection are summarized in table 2. 


figure 


ing 
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very hard if not impossible to see with most 
oscilloscopes. This dot clock is used to 
toggle flip flop IC4b which regulates the 
transmission data from memory to the video 
output. When IC4b is clocked by the dot 
clock, the data input on pin 12 from the 
memory is latched until another clock pulse 
appears. 

The second major portion of the 
GT-6144 (figures 4 and 5) consists of the 
memory and its associated components. 
When no data is being loaded into the 
terminal by a computer, appropriate outputs 
from both the horizontal and vertical coun- 
ters are used as address lines for the memo- 
ries. [C18 and 1C37 along with the necessary 
inverters form the decoders that select the 
appropriate memory integrated circuit (ICs 
27, 28, 29, 31, 32 or 33) depending on the 
location being addressed. Note that IC31 to 
(C33 can be enabled when CBO = 0 while 
ІС27 to ІС29 can be enabled when СВО = 1, 
therefore adjacent rectangles alternate back 
and forth between the two halves of 
memory. Тһе data outputs of ІС27 to ІС29 
are "wired OR” as are the outputs of 1C31 
to 1С33. AND-OR-INVERT gate IC10b 
selects which data will be transmitted to the 
video output depending on the state of CBO. 

The desired display for our graphics 
terminal is 64 cell positions across and 96 
cell positions down. This gives a total of 
6144 possible character positions which 
means that at least 13 address lines are 
needed since 212 = 4096 and 21? = 8192. 
Since some computers are not capable of 
sending out a 16 bit word, the most logical 
thing is to use two 8 bit words with some 
type of temporary storage in the terminal. 
The input control logic of figures 4 and 5 
serves this purpose. The temporary storage 
in the GT-6144 is done in flip flops IC34b 
and 1С41. Since the GT-6144 can accept 
data faster than most small computers can 
send it, only a DATA READY output from 
the computer is needed. This DATA 
READY line should be normally high and go 
low only after the data output from the 
computer is valid. During the time that the 
DATA READY line is low one of two things 
can happen. If the bit pattern from the 
computer is such that it is a horizontal 
position (bit 7 is O) IC30b will trigger, 
causing the data present to be latched into 
the flip flops. During this time the memory 
is unchanged. If the data present is a vertical 
position (bit 7 is 1) IC30b will not change 
state but IC39a or IC39c will, depending on 
the state of the latched low order bit О on 
pin 5 of IC41b. If IC41b pin 5 is 0, 1C39c 
will go low. When the counters come around 
such that CBO is 1 (the opposite side of the 


No. Device +5V GND -12У 
ІСІ 555 8 1 
ІС2 74279 16 8 
IC3 7451 14 7 
ІС4 7474 14 7 
ІС5 7404 14 7 
1C6 7493 5 10 
ІС? 7493 5 10 
ic8 7408 14 7 
Icg 7432 14 7 
ІС10 7451 14 7 
1C11 7420 14 7 
ІС12 7486 14 7 
ІСІЗ 7493 5 10 
ІСі4 7442 16 8 
ІС15 7409 14 7 
ІСІ6 74123 16 8 
1C17 7400 14 7 
IC18 7410 14 7 
ІС19 7493 5 10 
1C20 74157 16 8 
1С21 74157 16 8 
1C22 74157 16 8 
ІС23 7404 14 7 
ІС24 74157 16 8 
ІС25 74157 16 8 
ІС26 74157 16 В 
1C27 2102-1 10 9 
1С28 2102-1 10 9 
1С29 2102-1 10 9 
ІСЗ0 7402 14 7 
IC31 2102-1 10 9 
1C32 2102-1 10 9 
1C33 2102-1 10 9 
1C34 7474 14 7 
IC35 7400 14 7 
ІСЗ6 7404 14 7 
1C37 7410 14 7 
1C38 7432 14 7 
ІСЗ9 7410 14 7 
ІС40 7404 14 7 
ІС41 74174 16 8 
1C42 7410 14 7 
1C43 7408 14 7 


memory currently accessed by the video 
timing chain), IC40c will change state 
causing the data selectors IC24 to IC26 to 
select the address lines formed by the data 
from the computer rather than from the 
counters. IC18 will select and enable the 
correct memory integrated circuit and after 
a small time delay caused by C13, R31 and 
ІСІ5с, a low write pulse will be routed to 
the enabled memory. When the DATA 
READY goes back to its high state the write 
pulse will immediately disappear and after a 
small delay caused by R36, C17 and IC38b, 
the memory circuit will be disabled and the 
data selectors will return to addresses taken 
from the terminal’s video timing chain. Note 
that the data is written in one half of the 
memory while the terminal reads and out- 
puts data from the other half. The other half 
of memory works exactly as above but has 
BO equal to 1. 


Text continued on page 54 
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Table 1: Power Connec- 
tions for Integrated Cir- 
cuits, This table contains a 
complete fisting of the 
power connection pins for 
each integrated circuit in 
figures 3, 4 and 5. 


Table 2: Connector Pin 
Designations. There are 
three connectors, labelled 
J1, J2 and J3 in the fig- 
ures. The following are pin 
assignments for these 
connectors. 


J1: Power Jack 
Pin Assignment 
-12У 

+5 М 

GND 


6 VAC 60 Hz reference 
GND 


Филом 


J2: CT-1024 Connections 
Pin Assignment 


1 GND 
2 CT-1024 Data 
3 Reset 
4 GND 
5 GND 
6 Sync 


J3: Parallel Interface 


5 
5 


Assignment 


Bit 1 
Bit O 
Bit 2 
Bit 3 
Bit 7 
Data Ready 
Bit 6 


WOON OHA BWNH 


10 Bit 5 
11 Bit 4 
12 GND 


J3 
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ооо 42-2 


Figure 4: Input Logic. This figure contains 
the input control logic used to store the 
horizontal command information and de- 
code the vertical command or control com- 
mand information, 


LOGIC І TO IC4a 
(FIG 3) 


VERTICAL SYNC 
(FIGS) 


BLANKING 
(FIG3) 


*5V 


6С) 2N5129 
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МОТЕ: 

UNLESS SPECIFIED OTHERWISE - 
RESISTOR VALUES ARE IN OHMS. 
CAPACITOR VALUES ARE IN uF. 
DIODES ARE INSI4 / ІМ4148. 


Figure 5: Memory Logic. This figure contains the logic associated with the memory of the 67-6144. The 6144 bits of 
information used for the graphic output are contained in six 2102 memory integrated circuits. 
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Text continued from page 49 


When the computer sends out data where 
the high order bits B5, Bc and B7 =1(the 
control command mode), ІС42 pin 8 goes 
high so that no changes will be made in 
memory. Appropriate data lines from the 
computer are fed to the 7442 decoder IC14. 
1C39b disables the decoder in all but the 
control command mode. Depending on the 
data in low order bits O, 1 and 2 of the input 
to the GT-6144, the proper output of IC14 
is brought low to control the appropriate 
control function. The outputs of IC14 are 
latched in the 74279 circuit IC2. Pin 4 of 
IC2 controls the screen reversing function. 
1C34 prevents the screen from being reversed 
except immediately after a vertical sync 
pulse. While in the reversed mode the blank- 
ing pulse is removed, giving a totally white 
screen (except for characters). This switch- 
ing is done in IC3b. IC2 pin 7 controls the 
CT-1024 video data. When IC3 pin 4 is high 
CT-1024 data is enabled and disabled when 
pin 4 is low. Pin 9 of IC2 performs a similar 
enabling or disabling function for the 
graphics video data. Video data from ІСЗ pin 
6 is routed to IC15d where it is mixed with 
the appropriate blanking pulse. The outputs 
of IC15b and d are then mixed in 2N5129 


transistor Q4 to give the required composite 
video output. 

As shown in figures 3 to 5 the GT-6144 
unit should work on a video monitor or 
modified televison set. Because of rigid FCC 
requirements, the circuit has been designed 
to be connected directly to the video input 
circuit of a television. This typically requires 
the addition of a jack and if normal tele- 
vision reception is desired as well, a switch 
to select the operating mode. 

The data outputs from your computer 
must be at TTL low state for a logical O and 
TTL high state for a logical 1. The DATA 
READY line must stay at logical 1 normally 
and go to O only after the data from the 
computer to be loaded into the terminal is 
guaranteed valid. The DATA READY strobe 
should stay low for at least two micro- 
seconds and the data must stay valid during 
this time. Cable lengths from the computer 
to the terminal should be as short as 
possible. 

If desired the video from a SWTPC 
CT-1024 can be mixed with the video from 
the GT-6144 to give an alphanumeric or 
graphic display (or both) on the same TV or 
video monitor. No extensive modifications 
need be made to the CT-1024 but four wires 
do need to be added through J2.m 
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No Matter | 
How You Stack Them 


Ours Comes Out On Top! Д 


OUR FD-8 FLOPPY DISK SYSTEM Interfaces їо anybody’s 
microcomputer system via a single PIA chip! 

if you don't use PIA's, then one 8 bit bidirectional data port 
and one output only control port is all that's required — that 
simple! If you don't have a bidirectional port then separate input 
and output ports will do. 

Full sector buffering in ЗК of RAM contained on the 
controller card itself eliminates any dependence upon LIII ISDTPLIO 2) 
processor speed. TNS »-—44—-- 442 ce | 

Each drive is contained In its own cabinet with power и) “Ав зА — 
supply. Up to 4 drives may be daisy chained together and Аа 
selected under software control from a single controller card. 

Both single and double density, single or multiple drive 
units are avallable. 

Complete F DOS software for both 8080 and 6800 systems 
Is provided at no additional charge, including: disk driver 
subroutines, variable length file management system, disk 
assembler /editor, and integration with basic. 


MSI introduces the PR-1 PROM 
Programmer and verification module 
for use with microprocessor systems. 


The PR-1 Interfaces to any microcomputer system via 
a single PIA chip. The unit is designed to program 
1702A PROMS. Complete software for PROM 
programming Is provided with the system at no 
additional charge. 


MSI software products including our mini 
assembler, disassembler, and basic are now 
available on KC standard cassettes. Please 
specify either paper tape or cassette when 
ordering. 


For the past 6 years MSI has been a leading manufacturer of microcomputer data handling systems 
for medical laboratories, so we're not new to the business. Four years ago we introduced the first 
floppy disk system for programmable calculators, which is still in production today. We manufacture 
CRT terminals, PROM programmers, and a large selection of instrumentation interfaces. 

For more comprehensive product information, write MSI at the address below. Incidentally, our 
products are ready for immediate delivery. 


Master Charge & BankAmericard orders welcome. 


Here are two MSI Dealers, who can show you our products in action... 


Microcomputer Systems, Inc. American Microprocessors, 

144 S.Dale Mabry Ave. Equipment & Supply Corp. 
Tampa, Florida 33609 Chicagoland Airport, P.O. Box 515 
(813) 879-4301 Prairie View, Illinois 60069 


(312) 634-0076 


Midwest Scientific Tustruments 


220 WEST CEDAR, OLATHE. KANSAS 66061 * PHONE 913 764-3273 * TWX 910 749 6403 (MSI OLAT) 


Some Graphics Background 


Ira Jay Rampil 

University of Wisconsin — Madison 

Department of Electrical and Computer Engineering 
1425 Johnson Dr 

Madison WI 53706 


Information 


Computer graphics has come a long way 
since its inception as a laboratory curiosity. 
It is now a widely used tool for human 
information digesters. There is the old say- 
ing: “Опе picture is worth one thousand 
words" and thus information packed into 
computer generated pictures is now used by 
such diverse people as engineers, doctors, 
business people, and choreographers. We are 
now at the point where TV compatible 
graphics displays are affordable by hobby- 
ists, experimenters, and other randomly as- 
sorted computer freaks. 

Graphics hardware has also evolved far 
from the early dedicated processors and 
point by point plotting oscilloscopes to 
today's high resolution plasma displays (the 
so-called flat TV screens), computer gene- 
rated holograms, and intelligent multicolor 
vector displays. The vast majority of com- 
mercially available graphics, however, is still 
based on some kind of single color cathode 
ray tube. Even among the monochrome 
displays there are two different families of 
design, the storage tube design, and the 
continuously refreshed design. The purpose 
of this article is to present some background 
information on the philosophies represented 
by these two types of CRT systems, since 
they are important differences and have a 
large effect on the type of graphics each is 
capable of producing. 


Storage Tube Graphics 


Storage tube techniques can well be 
described as drawing on a paper pad with 
indelible ink. A line, once drawn, cannot be 
erased, except by tearing off and throwing 
away the entire sheet of paper. In other 
words, once completed, individual sections 
of a picture (also called subpictures, or 
glyphs) cannot be electronically deleted or 
moved without destroying and then re- 
drawing the entire picture. The need to 
redraw the entire screen might not be so 
bad, if it were not for the "erase flash," and 
the usually slow speed with which the 
graphics terminal communicates with the 
computer. The erase flash is a bright wink 
that always occurs when you wipe off the 
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screen of a storage tube. The slow speed is a 
mixed blessing, actually. These terminals are 
almost always used remote from the com- 
puter, and use simple asynchronous serial 
data lines, usually around 300 baud, to talk 
to the computer, just like a raster scan video 
display terminal. Using an ordinary tele- 
phone line for cheap communication, it can 
take several minutes to draw a reasonably 
complex image at 300 baud. At the very 
least, animation graphics, like Space War or 
LIFE, would prove cumbersome, and disap- 
pointing due to communications line limita- 
tions. These terminals are best suited for 
high resolution still lifes such as charts and 
schematics. Accessories to produce hard 
copy from the screen are usually available. 
Storage tube terminals have the advantage of 
being quite useful at great distance from the 
processor. They are also comparatively sim- 
ple in design and cheap to build. The 
exception is the price of the storage CRT, 
which can run over $1000 in “onesies” for a 
large high resolution tube, probably explain- 
ing why they are not often seen in amateur 
computing circles. 


Continuous Refresh Graphics 


The continuously refreshed or graphics 
processor type of display is like the storage 
tube display only in the way in which it 
draws a line or vector. There the similarity 
ends. In this system, vectors disappear al- 
most as fast as they are created. An image 
appears of constant intensity because it is 
redrawn or refreshed many times a second. 
This illusion, called flicker fusion, is the 
same principle by which the TV and movie 
industry simulate continuous motion. If an 
image flickers fast enough, the brain per- 
ceives it as continuous. Obviously, if there 
are many lines in the image, there has to be a 
very fast link between the display and the 
memory where the image data resides, in 
order to refresh the screen in the usual 1/30 
second (or 1/60 second for TV without 
interlace). Since drawing а previously 
created image is just a matter of shipping the 
picture information off to the display, and 
therefore requires no great amount of com- 


Perhaps the most dramatic example of the need for high resolution graphics is demonstrated by these pictures of the famous 
original” lunar lander program written for the Digital Equipment Corporation GT-40 and supplied with that unit as a 


demonstrator. These pictures were made by the author using University of Wisconsin facilities, and illustrate a couple of typical 
frames from the interactive graphics version of lunar lander. 


1638 NEL LETT -18 М cs 


.........% 


e. pupa 


Photo 1: The lunar mod- 
ule is controlled by a light 
pen, and is seen initially 
high above a lunar plane, 


по сагат те A BIG MC т 9. 


Photo 2: Eventually, if all goes well, the pilot (with his or Photo 3: Of course, if mistakes occur, there is a crash, This 
her magic wand control stick) lands the lunar module near picture shows the flying lunar lander above а lunar 
the golden arches of a famous fast food chain, orders some mountainside with “rocks” and the remains of previous 
food, takes off and leaves, crashes of the module by inept pilots. 


With the 256 by 256 graphics capabilities of the newer display output devices for televisions, the personal computer is getting 
close to the resolution needed to do the lunar lander simulations shown here, at a far lower price than was previously possible. 
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Table 1: Some graphics display devices listed for comparison. 


Professional 


Tektronix DEC 

Feature 4006-1 GT-40 
Design Type Storage tube Refresh vector 
Interface Bit serial DMA 
Point Plotting Hardware Hardware 
Vector Graphics Hardware Hardware 
Resolution High High 

1024 x 780 1024 x 768 

Drawing Speed Communications 200 us per 


Limitations interface limited vector (fixed) 

Character Hardware Hardware 

Generation 

Blinking Not possible Hardware 

Variable No 8 levels 

Brightness 

Remote Yes Yes—contains its 

Operation own PDP-11/05 

Altair Bus No No 

Plug in? 

Multicolor? No No 

Is Animation No Yes 

Possible? 

Hard Copy Yes Yes 

(Not Photos) lextra cost) 

Built-in Display? Yes Yes 

ROM Software Not applicable Only a 

in System (used with bootstrap 
large systems) 

Price Medium High 

(Kit price if ~$3000 ~$14,000 

available that 

way) 

Kit or Assembled Assembled Assembled 

Design Class High price High price 


EDITOR’S NOTES 


High resolution 
Commercial 


High resolution 


Commercial 


This table is by no means complete. It is 
intended to cover a spectrum of different 
systems with different prices and different 


user orientations. 


If each column is con- 


sidered to be a class of product, then the 
device shown is a typical member of that 
class. The rationalizations for selection are 


roughly as follows: 


e The DEC GT-40 and the Tektronix 


4006-1 are included for comparison 
purposes only to contrast prices of 
commercial equipment intended for 
use with large scale installations. The 
GT-40 virtually requires a minicom- 


Systems of interest to individuals 


15С SWTPC 
Intecolor GT-6144 


Raster scan Raster scan 


DMA Byte parallel 
Hardware Hardware 
Software Software 
simulation simulation 
Low Low 

160 x 100 96 x 64 


Byte transfer Programmed IO 


speed for each point 
Hardware Software 
Hardware Software 
No No 
Intelligent Yes 
terminal use 

No No 

Yes No 

Yes Yes 

No No 

Yes No 

Yes No 

System monitor 

Medium Low 
$1,395 (includes $98.50 
computer, dis- 

play keyboard) 

Kit Kit 
Complete system Low price 
with color Low resolution 
graphics Stand alone 


display generator 


puter, and is a very flexible (if now 
slightly outdated) system widely used 
by graphics hackers at university and 
research institutions. The Tektronix 
product and related products are 
within the range of a moderately 
wealthy private computer hacker, but 
are hardly products for mass con- 
sumption, The 4006-1 is also widely 
used in the university and research 
communities. 

The ISC system is an example of a 
complete system — computer, video 
display (color) keyboard, and sys- 
tems software in ROM — which is 
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MiniTerm 
Cromemco Assoc 
TV Dazzler MERLIN Matrox 


Raster scan 


Raster scan Raster scan 


DMA DMA DMA 
Hardware Hardware Hardware 
Software Software Software 
simulation simulation simulation 
Low Low Medium 
128 х 128 (BW) | 80 x 100 256 x 256 
64 х 64 (color) 160 x 100 
Byte transfer Byte transfer Byte transfer 
speed speed speed 
Software Hardware Software 
Software Software Software 
No No No 
No No No 
Yes Yes No 
Yes No No 
Yes Yes Yes 
No No No 
No No No 
No Yes No 
MERLIN 
monitor 
Low Low Low-Medium 
$215 $249 + $630 
$34.95/ROM 
Kit Kit Assembled 
(requires bus 
interface) 
Integral Integral Medium 
plug in for plug in with resolution 
color graphics systems black box 
software 


available in kit form at a price within 
the range of an individual. 

The Southwest Technical Products 
GT-6144 is a low resolution, low 
price stand alone product, intended 
to be absolutely the least expensive 
approach to the graphics output 
problem. The intention is quite well 
fulfilled. It does require a television 
or monitor, however, as do all the 
amateurs’ products except the ISC 
system. 

The Cromemco TV Dazzler is the 
first Altair bus compatible product 
available to amateurs at a reasonable 


puting, we needn’t bother the main proces- 
sor. Instead, we offer the display direct 
access to the memory where the image is 
kept. There are two ways to do this; the first 
is to allow the display to cycle steal, or have 
"direct memory access." This is the way 
many high performance commercial systems, 
like the DEC GT-40, work. This method 
does not allow the display to be far removed 
from the computer and its memory. In the 
GT-40, for example, the input to the display 
is about six inches from the memory board. 

The other approach is to give the display 
its own memory for the image, and its very 
own simple processor to keep track of what 
is going on with the display. The central 
processor then is allowed access to the 
display memory, and need only concern 
itself with the display when it wants to 
change the image. Thus the display can cycle 
through its own memory as it pleases, and 
the CPU can modify the image at a rate 
determined by economy and necessity. This 
is the method used by the typical homebrew 
or commercial video display used by BYTE 
readers. The local memories which have been 
used in these devices range from delay lines, 
shift registers, and programmable random 
access core or semiconductor memories for 
alphanumerics, up to dedicated disks for 
multicolored high resolution applications 
which require vast amounts of storage. 

The primary advantage of continuously 
refreshed graphics is high speed. This is the 
mode in which animation work is most often 
done. Since the images are stored in memory 
they are very easily manipulated at high 
speed. The resolution can be made equal to 
or better than storage displays. 

The currently popular personal systems 
displays use the refresh graphics method in 
combination with a video raster scheme. 
Instead of directly drawing vectors on a 
screen, they can only mark points that lie 
along the closely spaced parallel horizontal 
lines that make up a normal TV raster. The 
effect is to limit the maximum resolution to 


ALTAIR 8800 OWNERS 


We recently received the following letter: 


RUN 


GENTLEMEN: 


APRIL 26,1976 


1 JUST WANTED TO TELL YOU THAT 1 THINK YOUR CLOCK FIX-1T KIT IS 
REALLY GREAT! I WAS HAVING TROUSLE RUNNING BASIC AND AFTER 
INSTALLING YOUR KIT FOUR ОҒ XY HITS BOARDS THAT WEREN'T RUNNING 
CAME BACK TO LIFE AND NOW ARE HELPING НЕ TO WRITE THIS LETTER 
ON THE COMPUTER. ENCLOSED 15 ANOTHER ORDER FOR А CLOCK БІТ. 


THIS 15 РОН THE SECOND ALTAIR THAT Ital NOW IN THE PROCESS 


Cf BUILDING. 


AGAIN HANY THANKS FOR SUCH A FIRE FRUDUCT. 


SINCERELY 
LL-CYL Le SinITH 


How well does your Altair run? 
A Clock Fix Kit is only $15 postpaid. 


PARASITIC ENGINEERING 


PO BOX 6314 


about one third that of commercial vector 
displays. There is also an additional software 
burden on the processor whenever it is 
desired to simulate vector and character 
hardware. 

The chart accompanying this article as 
table 1 summarizes the characteristics of 
several representative graphics display 
devices. Take this table with a grain of salt, 
though, because today’s specs are tomor- 
row’s history. | expect that the features of 
amateur raster scan devices will eventually 
come close to the commercial continuous- 
refresh display, except, of course, for price, в 


price which could produce color 
graphics in limited 64 by 64 resolu- 
tion. Installation is a simple matter of 
plugging it into an unused Altair (or 
equivalent) computer slot. 

The MiniTerm MERLIN system is an 
example of a unique combination of 
character generator hardware, dual 
resolution black and white graphics, 
direct memory access to main 
memory, and systems software in 
ROM form. It uses existing memory 
of an Altair compatible computer as 
its graphics refresh source. 


е The Matrox display was not origi- 


nally intended for the personal sys- 
tems markets. It is not directly plug 
compatible with any particular com- 
puter, although interfacing to a 
bidirectional microcomputer bus is a 
straightforward matter. It has been 
promoted in engineering trade maga- 
zines as an “OEM” product. Circa 
August 1 1976 it is the опіу com- 
mercially available option for such 
high resolution at such a low price 
(Space War hackers take note). For 
further information, see “What’s 
New?” in this issue. 
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ALBANY CA 94706 


Graphics Display Memory 


Matrox Electronic Systems, POB 56, 
Ahuntsic Stn, Montreal, Quebec H3L 3N5 
CANADA, (514) 481-6838, has introduced 
this exciting new peripheral module for use 
іп generation of graphics outputs. The 
module is the MTX-256**2 graphics display 
memory, shown here along with the model 
1632 video display memory. 

The MTX-256**2 graphic display is a 
modular low cost graphic system designed 
for microcomputer applications. It displays a 


total of 65,536 dots arranged in a 256 by 
256 dot raster with each dot individually 
addressed under program control in less than 
3.4 us. 

The system consists of two modules. A 
central timing unit module (CTU) provides 
all television synchronization signals and 
interface timing signals for any microproces- 
sor and for image memory (IM) module. The 
image memory is a 65,536 bit programmable 
memory, and it stores one television frame 
(256 by 256) with one level of intensity. No 
external refresh is required. The image mem- 
ory is continuously scanned to produce a 
video signal that drives any standard mono- 
chrome or color television monitor directly. 


Expandability 

Using one CTU and one or more IM 
modules, various graphic systems can be 
designed by simple interconnections. Gray 
scale, color, image motion, light pen, cursor 
plot, vector plot, point plot, bar graph plot, 
alphanumerics and ROM screen patterns are 
easily implemented. 

The MTX-256**2 provides separate hori- 
zontal and vertical sync outputs which can 
be used to drive a slave MTX-1632 SL video 
programmable memory to obtain fully al- 
phanumeric graphic capability, as shown in 
the photo. 

The simplest graphic system 
(MTX-256**2-1) consists of one CTU mod- 
ule and one IM module. The system is also 
available as a single 6.5 by 6 inch (16.6 by 
15.2 cm) printed circuit board, +5 V (400 
mA); +12 V (120 mA). This unit will 
provide a 256 by 256 dot raster with one 


level of intensity (0. . black, 1.. white). It 
directly connects to a microprocessor data 
and address bus and no additional hardware 
is necessary. 

To a microprocessor an MTX-256**2 
looks like a write only memory with four 8 
bit locations. The locations with addresses 1 
and 2 are X and Y coordinates of a given 
dot. Cursor (dot address) is loaded by 
writing into X and Y address (8 bit each). 

The intensity (color) is loaded by writing 
into location 0. Existing cursor address is 
first advanced (moved to the next of 8 
possible directions, specified by 4 MSB bits). 
The remaining bits specify the intensity of 
the addressed dot. Location 4 is used for 
added intensity or color resolution (up to 24 
bits for each dot). Clear and present screen 
inputs are also available (minimum screen 
pulse width is 12 ms). 

Output is a standard composite video 
signal (75 ohm, crystal controlled). Both 
American (60 Hz rate) and European (50 
Hz) versions are available. Price is $598 in 
unit quantities for the basic MTX-256**2-1. 
Delivery is 2-8 weeks. 


Editor's Note: 


In conversation with Lorne Trottier of 
Matrox, at the Personal Computing 76 show 
in Atlantic City, 1 learned of Matfox's 
intention to create a variation of the display 
described here which will plug directly into 
the Altair/IMSAl/etc bus [nested note: un- 
officially grapevined as the “5100” bus to 
eliminate the kluge of listing all the names of 
all the processors using it... CH] ... CH] 


Introducing The First Professional Quality Modem In Kit Form... 


The Pennywhistle 103 


Tbe Pennywhistle 103 Acoustic Coupler is the first professional quality modem available in kit form. The Pennywhistle 
may be used either as an acoustic coupler (with the telephone handset) or it may be wired directly into the telephone. In 
either case, the Pennywhistle will operate in both the half-duplex (unidirectional) or the full-duplex (bidirectional) modes. 

The Pennywhistle 103 is capable of recording data to and from audio tape 
without critical speed requirements for the recorder and it is 
able to communicate directly with another modem 
and terminal for telephone ‘‘hamming”’ and com- 
munications for the deaf. In addition, it is free of 
critical adjustments and is built with non-precision, 
readily available parts. 

One of the most significant problems associated 
with modems is that there is often difficulty in deter- 
mining the difference between a signal of the proper 
frequency and one of its harmonics. The Pennywhistle 
103, however, employs a tbree-stage active filter which 
prevents noise and harmonics from getting through. 

The Pennywhistle kit includes everything needed for 
the entire unit. All electronic components mount on а 5" 
by 9” printed circuit board. The kit also includes all chassis 
parts, speakers, speaker grilles, muffs and line cord. 

But just as important, the Pennywhistle is backed up with a 
complete documentation manual. This manual describes — in de- 
tail — what a modem is and how it works. All theory of operation 
discussions are keyed to a block diagram and schematic. This man- 
ual also contains a thorough set of assembly, test and adjustment 
instructions as well as directions for hooking the Pennywhistle up 


for 
direct wire 
connection, modem-to- 
modem communication, tape re- 
corder connection and long distance use. 


Tbe Pennywbistle 103 modem kit is $109.95 (plus 
$2.50 for postage and bandling) and is available from 
M&R Enterprises, Р.О. Box 61011, Sunnyvale, Са. 
94088. California residents add 696 sales tax. Allow 
approximately four weeks for delivery. 
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Introducing A Remarkable New Microcomputer: 


The Astral 2000 


You're reading this ad, so you're obviously interested in getting a microcomputer. You're probably also a bit confused by the 
number of different microcomputer kits around today. So, think about the things you want in a microcomputer. Ease of assembly, 
quality power supply, well designed cabinet and interconnect scheme, peripheral and memory options for an expanding system. 


Some Kit! 


Although we have called the Astral a “kit”, it actually arrives 
over 70% assembled. The power supply, processor board and RAM 
board are fully assembled, burned in and tested before shipment. 

There is no complicated wiring harness. In fact, there is no front 
panel wiring harness at all. The front panel plugs directly into the 
backplane. Additional circuit boards are inserted through the rear 
of the chassis directly into the backplane. 


Complete System 


The Astral 2000 is shipped with power supply, cabinet, front 
panel components, mother board, processor board and one 8K RAM 
board. The processor is 6800-based and operates in serial and in 
parallel. Both RS-232 and 20mA current loop are provided by a ser- 
ial I/O socket on the processor. This processor is shipped with our 
own 16K monitor ROM and has provisions for ‘‘cycle-stealing”’ 
DMA. The memory board contains 8K of low power, 500ns static 
RAM and uses less than 1.5A at 5V. 


Lots Of Options 


А computer isn't much fun if you can't talk to it. But you can 
talk to the Astral with the VID-80 video terminal board for only 
$189.95 unassembled ($245 assembled). The VID-80 has a selectable 
line length of 64, 72 or 80 characters per line. It displays 16 lines 
of upper case characters but gives you the option of installing a 
lower case character ROM as well. 

We also have someplace for you to put your programs. Our 8K 
EPROM board ($59.95) is designed for the 5204 and will allow in- 
System program storage even during power-down. This board is 
assembled with all components except the EPROMs, however 
Sockets are provided for the memory chips. 

We've solved program loading, too. The I/O tape interface unit 
($49.95) plugs into the I/O socket on the processor board and allows 
programs to be loaded from any inexpensive, non-digital tape deck. 
But if tape cassette isn't fast or big enough, a floppy disk with an 
Astral bus-compatible controller will be available for under $1,000 
in the last quarter of 1976. 


A New And Powerful BASIC 


A unique and powerful version of BASIC with features never 
seen before in an 8K version has been designed especially for the 
Astral system. Astral BASIC contains all the features of competing 
BASICs and then some; Astral BASIC is also very fast. 

With the User Selectable Floating Point package, the user 
chooses the degree of precision from the four choices of 6, 9, 13 or 
16 digits. Fewer digits use less memory and is faster, however higher 
precisions are useful for scientific and mathematic applications. 

The Astral BASIC's DO statement is unique; it has never 
appeared in any other version of BASIC. The DO statement is a 
simple and flexible way to subroutine without the restrictions of 
formal subroutines. DOs can be nested, too and — of course — Astral 
BASIC has all the other standard subroutine procedures as well. 

The Trace Mode is another feature rarely found in other 
BASICs. The Trace Mode is used in program debug to list statement 
line numbers as executed. This feature may be programmed to 
Trace On only for routines still needing check-out. Pressing the 
escape key halts the trace and returns control to the terminal. 

The Astral BASIC string facility permits variable length strings 
of unlimited length and includes the ability to search for a substring 
within another larger string, a particlularly useful feature for word 
processing applications. 

Powerful program editing capabilities allow loading, listing and 
saving of programs. Blocks of statements may be deleted or renum- 
bered. The RENUMBER statement may be used to increment all 
specified line numbers and it automatically adjusts the numbering 
of any GO TOs, etc. 

Another feature never seen before in an 8K version is the pop- 
ular PRINT USING statement. PRINT USING permits floating “$”, 
“+” and '—" signs as well as floating commas, so numbers such as 
$1,000,000+ can be printed in the standard accounting format. 


ЙА А Mer enterprises 
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The Astral 2000 is 8995 partially assembled ($1250 fully assembled) plus $14 for shipping апа handling ($18 for Canadian 
orders). Additional 8K RAM boards are $245 each. California residents add 6% sales tax. The Software Package includes Astral 
Basic on magnetic tape cassette or paper tape, the game of Startrek, complete documentation and a free one year subscription to 
the Astral Newsletter, all for $35. For more details, send a self-addressed, 8% by 11 stamped envelope to M&R Enterprises, P.O. 
Box 61011, Sunnyvale, Са. 94088, Allow approximately 8 to 12 weeks for delivery. 


Product Description: 


The MERLIN Video Interface 
Adds a Visual Dimension 


to Your Altair or IMSAI 


What is missing when you purchase a main frame computer from the 
catalogues of MITS Inc or IMS Associates? Asking that question has recently 
started several companies purveying products to the small systems market. 
The identification of gaps in a product line, then independently filling these 
gaps is a highly respected tradition in the computer field, a tradition which 
has hardly changed as the market widens through microcomputer technology. 
An example of a creative and innovative product idea which augments and 
enhances an existing computer product line is provided by the new MERLIN 
board manufactured by MiniTerm Associates, Bedford МА. The following 
article is edited from materials supplied by MiniTerm. 


MERLIN (trademark of MiniTerm Asso- 
ciates) is a new concept in peripherals 
modules for mainframe microcomputer 
systems. It is a combined hardware and 
software package which provides a keyboard 
video interface with 20 lines of 40 ASCII 
encoded characters, graphics with a resolu- 
tion of 100 by 160 points, and read only 
memory software for Monitor and Editor 
programs. The entire price of this unit, $249 
plus $34.95 for the ROM software, is well 
within the budget of many small systems 
users. In fact it is hard to find a combination 
of the features MERLIN has which even 
approaches the cost effectiveness of this two 
card Altair and IMSAI compatible plug-in 
system. Output is an EIA standard video 
signal to drive a TV monitor or modified 
television set. 
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MERLIN'S two boards provide far more 
than just an ASCII and graphics interface. A 
sophisticated DMA controller allows MER- 
LIN to display information from any part of 
the computer memory. Also, since the dis- 
play starting address is software controlled, 
the memory segment displayed can be 
changed with every screen refresh. 

The number of ways in which the mem- 
ory selected can be displayed boggles the 
mind. And since the display mode is soft- 
ware controlled, it too can be changed with 
every refresh. One useful mode option saves 
memory by beginning a new line whenever a 
carriage return is detected — eliminating the 
need for spaces to the end of a line. This 
enables typical text or program source code 
listings to be stored in 30 to 5096 savings of 
memory space depending on the actual text 
data involved. Another mode selects white 
or black characters. Control characters can 
be inverted or blanked — great for storing 
"invisible" information on screen for some 
games. Carriage returns are displayed as 
boxes or blanks and the cursor winks or 
remains steady. The dense graphics mode 
enables 2 K words of memory to be dis- 
played as 160 dots horizontally by 100 dots 
vertically, or if memory is in short supply, 
1 K bytes can be used to display as 80 dots 
horizontally by 100 dots vertically until 
your next birthday. 


The POLY 88 
Microcomputer System 


The POLY 88 Microcomputer System brings to the 
user, in one compact package, the capability of 
developing programs and hardware as well as 
enjoying the interaction with computers. The POLY 
88 System uses a video 
monitor for display, a 
keyboard for input, and 
cassette tape for storage. 
The system will connect toa 
hard-copy terminal. POLY 
88 hardware consists of 
CPU circuit card with on- 
board memory and I/O, 
video display circuit card 
with keyboard input port 
and graphics capability, and 
mini-cards that connect to 
the CPU board via ribbon 
cable for cassette or serial 
interface. 

Central Processor Card 
features 512 bytes of RAM 
(random access memory), 
plus sockets for up to 3K of 
2708-type PROM or ROM 
(read only memory), 
vectored interrrupt, and real 
time clock, as well as an 
optional serial input-output 
port featuring software- 
controlled baud rate. 

The Video Terminal Interface circuit card will 
generate 16 lines of 32 or 64 characters or 48 x 128 
graphics grid on astandard video monitor or slightly 
modified TV set. It also includes an 8 bit parallel 
keyboard input port, allowing the board to function 
as the complete computer interface. 

The POLY 88 Chassis and backplane/motherboard 
is Altair compatible and will provide 6 amps of 
power to five cards. Only two switches are mounted 
on the front panel — a lighted on/off switch, anda 
push-button, which, in addition to resetting the 
system, indicates a halt condition in the processor. 
The firmware Monitor is integral to the POLY 88 
System. This 1024 byte program in ROM allows the 
user to display data on a TV screen, enter data into 
memory using a keyboard, read and dump data to 
the cassette interface in a standard format, and 
single step through a program while displaying the 
contents of each of the 8080’s internal registers. 


The monitor provides many of the standard driving 
routines to greatly simplify the job of programming. 
The monitor forms the basis of an ever-increasing 
software library available to POLY 88 owners. 
Options from PolyMorphic 
Systems include a board 
with 8K of additional KAM, a 
versatile prototyping board 
(“The Ideaboard”), and an 
Analog Interface. Also, 
many “Altair-compatible” 
products on the market are 
compatible with this system. 
Prices: Basic kit including 
chassis, CPU and video 
cards — $595, $795 © 
assembled. Cassette option 
— $90 kit and $125 
assembled. 8K of RAM — 
$300 in kit form or $385 
assembled. We also sell the 
video and other “Altair- 
compatible” circuit cards 
separately. 
Dealers: This system sells 
itself. 
All prices and specifications 
subject to change without 
notice. Prices are USA only. 
California residents add 6% 
sales tax. 
Prepaid orders shipped postpaid. BankAmericard 
and Master Charge accepted. 
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PolyMorphic Systems (805) 967-2351 
737 South Kellogg Avenue Goleta, CA 93017 


PolyMorphic 
Systems 


If you are worried about loading all those 
great bytes into your machine with toggle 
switches, don’t. MERLIN provides a parallel 
input port to which most keyboards may be 
directly tied and sufficient regulated power 
to run them. MERLIN also has a serial input 
port which may be used for binary data 
from tape signal conditioners, switches, 
thermocouples or other arcane hobbit para- 
phernalia. The serial output port is also 
uncommitted, and the pair can be used to 
implement a cassette !O interface. 

Best of all, you need not be a software 
genius to use MERLIN. Monitor and Editor 
functions as well as general purpose sub- 
routines, selectable ІО drivers and keyboard 
and display drivers are also stored in MER- 
LIN's optional on board МВ1 ROM. (If you 
are a software genius and have a programmer 
you can substitute up to 2 K of your own 
2708 EROM or 1 K of 2704 EROM.) Pro- 
vided with the MBI ROM are also 128 words 
of scratchpad programmable memory to 
hold MERLIN's vital statistics and Monitor 
stack. Linkage through this scratchpad to 
user defined routines creates a system which 
can be expanded virtually without bound. 
(As though the ten user defined keystroke 
executed functions built into the monitor 
weren't enough!) 

Monitor functions provided by the MBI 
ROM include the ability to fill any portion 
of memory with a given hexadecimal value, 
the ability to sequentially modify memory 
contents, and hexadecimal dumps to the 
display. Processor registers may also be 
examined or modified. ASCII text may be 
input to memory, blocks of memory may be 
copied, the beginning and end of the display 
area and display format may be set, and user 
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programs may be executed with up to three 
breakpoints. The breakpoints enable the user 
to return control to the Monitor after 
executing only part of his code. Once in the 
Monitor the user may examine or modify 
memory or registers before executing more 
of his program. 

The Editor functions can be invoked by 
keystrokes or called from user programs. 
The functions include: 


Control of cursor movement (up, 
down, right, left, home, two tab sets, and 
tab). 

Either characters or lines may be 
inserted, deleted, or replaced. 

Scrolling can be automatic at any line 
number or under manual or program 
control. Scrolling may be page up or page 
down or absolute. 

Automatic scrolling can provide wrap- 
around at the end of the defined display 
area (up to 64 K), so that using the "clear 
display after cursor position" and "copy 
block" functions provides an easily imple- 
mented “infinite” display area. 

Finally, this ROM contains direct 
linkage to a second optional 2 K ROM 
and forthcoming cassette-modem inter- 
face ROM. MERLIN's second ROM con- 
tains extended Monitor/Editor functions 
plus general purpose graphics control 
subroutines. 


A soon to be announced optional board 
for MERLIN will increase capabilities to 
include color graphics, and with 320 hori- 
zontal by 200 vertical resolution for black 
and white graphics.MiniTerm Associates is 
located at Box 268, Bedford MA 01730.m 


IF YOU CAN'T FIND IT OFF THE SHELF 
TRY THE DATA DOMAIN 


We are proud to announce we are now dealers for the Digital Group. 


Processor Tech 


[Dara L Domain 


Continued from page 16 


run APL, SNOBOL, LISP, PASCAL, 
ALGOL, TRACT etc), and with the falling 
prices of memory, will do exactly that. I 
know several personal computer hackers 
who have pretty nearly filed up a 64K 
memory address space. If a person has a 
choice between a system that costs $1000 
with 16 K of memory and the same system 
with 32 K at an incremental cost consistent 
with the new 16 K chips’ estimated costs, 
the extra $300 to $500 at the store may be 
well worth it; and as the technologies 
improve, more and more memory will be 
potentially possible for the same dollars. 

And there lies the problem. With memory 
getting cheaper and cheaper, we are running 
out of address space in the 8 bit LSI 
processor! The typical 8 bit or 16 bit LSI 
processor addresses 65,536 bytes and that's 
all. For many purposes, such as creating data 
base structures with large buffered data areas 
internally, it would be extremely convenient 
to have much larger main memory areas. For 
instance, in a super text editing system 
allowing 50 K bytes for buffer areas limits 
one to about 18 standard manuscript pages 
in memory at any given time (assuming no 
paging to expensive electromechanical mag- 
netic media). With memory becoming a very 
cheap commodity, one would like to have as 
much of it as possible on line for such 
applications. Similarly, in setting up infor- 
mation management systems for the home 
user, the more memory the better, since the 
resource can be used both to speed up 
computation by using table concepts, and to 
minimize IO. 

Given this desire for lots of memory, and 
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the limitations of 16 bits, the search for 
alternatives is bound to occur. One place 
that this can come out is in newer 151 
processor designs. For example, consider the 
Motorola 6800 as it is presently imple- 
mented. It resides in a 40 pin package, but 
the simplicity of its interfacing requirements 
leaves two pins unused at present. In a 
hypothetical “improved” version, the design 
could be modified to support 18 bits of 
addressing, or a maximum of 256 K bytes 
(262,144 bytes) with some changes in the 
internal architecture. The simplest internal 
change would be to use the uncommitted 
bits of the status register (bits 7 and 6) as 
"bank selection" bits to implement ex- 
tended external memory by the traditional 
"bank switching" trick. Of course, it's 
hardly likely that this design change will 
happen, so the extension to memory sizes 
above the address range of the machines will 
have to be accomplished by the individuals 
designing the computer products which 
employ LSI central processors. 


Bank switching kluges can be done exter- 
nally to a processor as well. In a personal 
computing system with ROM software of 
compilers or interpreters, one way would be 
to partition a 32 K segment of address space 
into two 16 K regions along the boundaries 
of the 16 K chips, with bank switching used 
to alternate such extended regions of mem- 
ory. Again, in a hypothetical case, consider a 
4 bit mapping vector for each 16 K half of 
this region of addressing. The 4 bit bank 
selection could point to 16 banks of 16 K 
bytes or 256 K bytes, with the core of 32 K 
bytes retained for system monitor and IO 
functions. But these are just conjectures of 
ways to accomplish the extension of mem- 


65 


111 S. College Av 
Bloomington, Ind. 47401 
Phone (812) 334-3607 


Articles Policy 


BYTE is continually seek- 
ing quality manuscripts writ- 
ten by individuals who are 
applying personal systems, or 
who have knowledge which 
wil prove useful to our 
readers. Manuscripts should 
have double spaced type 
wxitten texts with wide mar- 
gins. Numbering sequences 
should be maintained sepa- 
xately for figures, tables, 
photos and listings. Figures 
and tables should be provided 
on separate sheets of paper. 
Photos of technical subjects 
should be taken with uniform 
lighting, sharp focus and 
should be supplied in the form 
of clear glossy black and white 
оу color prints (if you do not 
have access to quality photog- 
raphy, items to be photo- 
graphed can be shipped to us 
in many cases) Computer 
listings should be supplied 
using the darkest ribbons pos- 
sible on new (not recycled) 
blank white computer forms 
or bond paper. Where possible, 
we would like authors to sup- 
ply a short statement about 
their background and experi 
ence, 

Articles which are accepted 
are typically acknowledged 
with a binder check 4 to 8 
weeks after receipt. Honorar- 
iums for articles are based 
upon the technical quality and 
suitability for BY TE's reader- 
ship and are typically $25 to 
$50 per typeset magazine 
page. We recommend that 
authors record their name and 
address information redun- 
dantly on materials submitted, 
and that a return envelope 
with postage be supplied in 
the event the article is not 
accepted. m 


Authors take note: А 
tutorial on the architec- 
ture of stack machines, the 
reasons for using such 


machines, and what it is 
like to program such a 
machine would be excel- 
lent article material for 
BYTE тадагіпе. в 


ory, given the need for utilizing existing 
machine architecture. 


Enter the Stack Machine 


The real reason we need to use more 
memory than 64 Қ is our need to use high 
level language to program sophisticated 
information constructs. Traditional 151 
processor designs to date have merely been 
adapted versions of widely used designs to 
the constraints of LS] technologies. A 6800 
is simply an 8 bit approximation of what 
minicomputers have always been, and 
minicomputers are just miniature versions of 
the earlier, larger machines. Sure, improve- 
ments in architecture have been made, such 
as use of subroutine linkage stacks with 
built-in pointers, but all the present LSI 
processors are cut of the same mold. If we 
are running out of room in address space 
with the present designs because of a need to 
run high level programming languages and 
intricate information systems written in 
these languages, why not use the need for 
larger address space as a superficial spur for a 
high level language oriented general purpose 
processor itself? 

There is a whole technology of machines 
oriented towards high level languages, a 
technology principally seen in the com- 


mercial products of the Burroughs Corpora- 
tion and experimentally in computer science 
and software engineering contexts. This is 
the technology of the high level language 
machine, or stack machine. This is a proc- 
essor designed to have a machine language 
which is very close to a high level language 
consistent with structured programming con- 
cepts. This is the world of the computer 
whose instruction set includes control struc- 
tures like the IF instruction, the THENDO 
instruction, the ENDELSEDO instruction, 
the ENDIF instruction, and data constructs 
appropriate for a high level language. The 
grapevine currently jingles with rumors that 
such a machine will soon be on the market, 
possibly labelled “790”, and | know of at 
least one university laboratory version in- 
tended for reduction into LS! masks. High 
level languages are what make general pur- 
pose computers useful to the largest number 
of people, so eventually | expect to see stack 
machines in LSI form, intended for general 
purpose computers. 

Use of stack machines sure won't cure the 
address space saturation problem, but if one 
has to add some extra bits to the memory 
address bus, why not include a real improve- 
ment in the processor architecture at the 
same time as the new design is created?m 


Publisher's Notes 


Personal Computing 76 in Atlantic City: 


Something for Everyone 


by Virginia Peschke 


Personal computing enthusiasts were 
treated to a huge, successful convention in 
Atlantic City on August 28 and 29. BYTE 
will have a complete pictorial report next 
month, but briefly: More than 80 manu- 
facturers and suppliers had booths to display 
their latest products and exchange ideas with 
users; dozens of technical talks and several 
seminars provided information on every 
phase of personal computing; and a huge 
supply of valuable door prizes was dis- 
tributed to many lucky attendees. 

The speakers at the Saturday night 
banquet were all greatly entertaining. As a 
grand finale, John Whitney showed his tech- 
nically amazing and esthetically beautiful 
movies of animated computer graphics with 
musical accompaniment. Though everyone 
had had a full and exhausting day, John's 
movies held us all spellbound until almost 
one in the morning, and various persons 
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inspired by the show were engaged in con- 
versation until much later. 

For those of us who aren't true computer 
hackers (I'm a jade carving nut myself) the 
choice of Atlantic City as a site was indeed 
fortuitous. Though it's somewhat difficult to 
get to from some parts of the country, once 
there the computer hacker is relieved of the 
usual domestic problem; that is, how to keep 
the family entertained. Atlantic City offered 
so much for the people who didn't wish to 
spend much time at the show that the 
computer buff was unlikely to hear "We've 
been here an hour, when can we go?" First, 
there was the superb sand beach with a 
warm, gently rolling ocean, the amusement 
park, the boardwalk train, and the great 
selection of restaurants and shops. Where 
else could one find, within several blocks of 
each other, dealers in crystal paperweights, 
archaic Chinese jade, oriental rugs, British 
tweeds, Spanish lace, magic tricks, health 
foods, and many other things too numerous 
to list? No, families were not bored and 
hackers were free to spend all the time they 
wanted exchanging information.m 
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Based оп fliers picked up at the Personal 
Computing 76 show in Atlantic City, 
August 28 and 29: 

Edityper Systems Corp, subsidiary of 
Tycom Inc, 26 Just Rd, Fairfield NJ 
07006, is manufacturing a do it your- 
self Selectric typewriter conversion 
kit. This “еаѕу to install” kit for any 
IBM Selectric | or Selectric ЇЇ type- 
writer "provides quality hard сору 
output for all microprocessor devices." 
The kit contains four modules: a 
selection assembly, function group 
assembly, shift assembly and tab 
assembly. It is driven by a 50 pin 
connector and requires user supplied 
power of 27 V at 1 A peak, and 5 V at 
0.2 A. The price is $395 plus shipping. 
We'd be most interested in publishing 
3 photo article by a reader who installs 
this item in a typewriter and integrates 
it as hard copy output for his or her 
system. 


STM Systems, POB 248, Mont Vernon 
NH 03057, showed off the new Baby! 
Floppy Diskette Storage System, This 
new “mini floppy" drive with power 
supply and controller will be available 
in the near future for $750. It uses a 
miniature floppy disk of about 5 
inches (13 cm) diameter and stores 90 
K bytes (formatted) on 35 tracks with 
average latency of 100 ms, 350 ms 
average access time. The drive was 
shown in prototype form at the con- 
vention. 


Miscellaneous 
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SPACE VOYAGE 


The most complete space simulation game ever offered to micro users, Your 

mission 15 to rid the galaxy of the enemy using your warp engines, phasers, 
photon torpedoes, short and long range scanners, teleporter, shield control 
and damage control. Beware of enemy attacks, supernovas, space storms, and 
other distrubances. To duplicate this game using BASIC would require about 
20K but your 6800 needs only 4K to run this exciting program. $10.00 


FLOATING POINT PACKAGE 


Using this program you can do arithmetic operations with 9 significant 919- 
its and an exponent range of -99 to +99. Add,subtract,multiply,and divide 
are implemented in 512 bytes, We Include free 1/0 driver program. $5.00 


SCIENTIFIC PACKAGE 


All the scientific functions you need - SIN, COS, TAN, ARCSIN, ARCCOS, ARC- 
TAN, exponentials, LOGX, LNX, hyperbolics, and more. Must be used with the 
Floating Point Package above (not included). $10,00 


MICRO BASIC PLUS 


PRINT, INPUT, READ, DATA, RES, GOSUB, GOTO, ON GOSUB, ON GOTO, RET, LET, 
IF, FOR, NEXT, REM, END, 1 and 2 DIM arrays, RUN, LIST, SCR, EXT, MON, RND, 
TAB, SPC, ABS, SGN, EXP, multiple statements per line, simple load and 
dump. А АК system leaves approx ІК for programs (50 lines). $15.95 


PROGRAM OF THE MONTH CLUB 


For $2 you get a one year membership and receive monthly bulletins describ- 
ing our newest programs. Up to 152 discount on the featured program. No ob- 
ligations, You get our Random Number Generator free if you joln now. $2.00 


CASSETTES 


Several programs are now available on "Kansas City" standard, MIKBUG for- 
matted audio cassettes. No instructions or listing included, must be pur- 
chased separately. CT-1 SPACE VOYAGE $8.95, CT-2 KLINGON CAPTURE $6.95, 
listing $4.75, CT-3 HANGMAN and ACEY-DUCEY $6.95, listings $3.25 each, 
CT-4 MASTERMIND and SWITCH $6.95, listings $3.00 and $2.00 respectively. 


INFORMATION 


Our source listings contain comments throughout, label table, hex code dump 
complete instructions, and sample output. External references (to MIKBUG 
routines) are easily modified. When ordering add $1 postage and handling 
under $10, 5% for first class mail, 4% sales tax (Ind. residents). Person- 
al checks will clear bank. Many other programs, for information send SASE. 


TSC Technical Systems Consultants TSC 
Box 2574 W. Lafayette IN 47906 
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TERMINAL SYSTEMS DIVISION-DAYTON 


We have a number of new and challenging 
opportunities involved with the hardware/soft- 
ware design and development of real-time finan- 
cial terminals. Immediate needs are at all levels 
in the following areas: 


PROGRAMMER/SYSTEMS ANALYSTS 


These positions require knowledge in the areas of 
microprocessors and minicomputers based on real-time 
operating systems. Responsibilities will be to participate 
in the design of software development and write test 
software for mini and micro based real-time operating 
systems in a distributive network. 


An opportunity also exists for participation in the 
architectural design of an Automated Health Care 
System. 


Candidates should have a BS/MS degree in Computer 
Science or Math and at least 3 years programming 
experience. Experience with assembly and COBOL 
languages is necessary. 


SOFTWARE SYSTEM DESIGN 


These positions require the ability to provide technical 
expertise and leadership in the area of real-time terminal 
control and batch operating systems. Responsibilities 
will be to translate and interpret the state-of-the-art in 
operating systems to an assigned terminal control project 
and to select, influence and affect broad technical 
directions in software. Will be responsible for coordi- 
nating complex distributed processing operating system 
software development which will support applications 
coded in high level languages and run in both microcom- 
puter and minicomputer mode environments. 


Candidates should have an MS degree in Computer 
Science, Systems Engineering, or Math, and 7 to 10 
years programming experience with at least 5 years in 
operating system design and development. 


These positions are at NCR’s Terminal Systems Division 
in Dayton, Ohio. If you qualify and are interested in 
these opportunities, submit your resume and salary 


requirements to: Robert L. Opalek, Manager 
Employment Department 
Terminal Systems Division-Dayton 
NCR Corporation 
Dayton, Ohio 45479 


An Equal Opportunity Employer 


Letters 


ZEROING IN 


| think the point has again been missed in 
the great 8080/6800 controversy. 

Reader Cochran (August 1976) compares 
the [O structure for what seems to me the 
millionth time. Really now, what would it 
take to convert one bus to the other? A 
couple of AND gates maybe. And who cares 
if the 6800 has a few less memory locations 
out of 65536? 

The major difference is the purpose be- 
hind the two instruction sets. While the 
8080 is superior at handling structured data, 
the 6800 is better at arithmetic. The former 
has an overloaded accumulator while the 
latter has an overloaded index register. 

The single accumulator of the 8080 re- 
quires many transfers to temporary storage. 
This is most frustrating when doing calcula- 
tions that involve intermediate results. Un- 
fortunately, the arbitrary nature of the 
instruction set makes improvement difficult. 
Zilog's Z-80 is a slight improvement, but 
only compounds the inconsistencies already 
present. 

The 6800's major fault is its lack of index 
register capability. However, improvement 
by adding instructions is easy. There should 
be an instruction to push the index register 
onto the stack and one to pop it off. An 
instruction to compute a 16 bit address by 
adding the accumulators to the index reg- 
ister is essential for reentrant programming. 

Both the 6800 and the 8080 need im- 
provement. Because the 6800 has a cleaner 
architecture, it has greater potential. So 
when Motorola comes out with a replace- 
ment chip, I'll be first in line. [Not if I get 
there first. . .CH] 


Stephen Ma 

Glenn Fawcett 

5170 James Walk 

Vancouver BC CANADA V5W 2K4 


Grapevine, Austin TX, has it thal the new 
MC6809 product (the Motorola answer to 
2-80) will have: Two 16 bit true index 
registers, block move, block search, and 
perhaps even some 16 bit arithmetic to 
enhance pointer manipulations and address 
calculations at run time. 


A CASE OF DUPLICITY? 


Finally ariving home from work after 
another hard day, seeing my August issue of 
BYTE in the mailbox immediately calmed 
my nerves. I settled into my semi-automatic 
reading chair, placed my copy in the scan- 
ner, punched up a beer and sausage combo 
on the console and prepared to better 
myself. Greedily | began. Not wanting to 
flounder about, | immediately flipped to “In 
This BYTE.” The highlights leaped at me. 
Another fantastic array of information! (Up 
to this point, І had read every issue of BYTE 
cover to cover and this one promised to 
maintain the trend.) 

| read to the blurb about the Zilog 780 
and no farther. Expecting to find informa- 
tion to delight and astound me, | started 
flipping toward the article. One page farther 
and the ad for the "super chip" whet my 
appetite and set me flipping furiously. My 
expectations only rose as | skimmed for page 
34 and the ‘Microprocessor Update: Zilog 
Z80". Page 25. (Just nine more.) Flip. Flip. 
Page 32. Flip. Page 50!!! Flip back. Page 32. 
Flip. Page 50??? 

| tore my BYTE from the scanner, and 
manually searched for page 34, but nowhere 
could | find it. It seems my copy jumps from 
page 32 to 49, and again from page 80 to 97. 
The fact that there were doubles of pages 
17-32 and 97-112 didn't seem to make up 
for my loss. 

| fell back, dejected, just as my chair 
served me my beer. But the force of me 
collapsing backward thrust my beer into the 
vibrating unit which promptly shorted out, 
flinging me headlong across the room. 

| am now in traction in the county 
hospital. 1 am also very dejected because 
now | have all this time and still can't read 
about the Z80. Could you find it somewhere 
in your heart to fill this emptiness. 


Deplorably yours 


W R MacLeod 

СТЕ Automatic Electric Labs 
4501 W North Av 

Melrose Park IL 60160 


Mr MacLeod received the following reply: 


Dear Mr MacLeod 


Enclosed you will find a complete August 
issue of BYTE. We hope you enjoy reading 
the article “Microprocessor Update: Zilog 
280,” during your stay in the county hospi- 
tal. If it appears to be an extended stay, 
please let us know if we may forward the 
September and October issues to you. 

The staff at BYTE wishes you a quick 
recovery. 


[Any reader who received a similur glitch 
should send hislher BYTE back for re- 
placement. ] 


COMPUTER PHREAQUENCY 


BYTE No. 13 (September 76), page 12, 
letter from Melvon С Hart, WOIBZ, "Atten- 
tion Hams! ..." Try 3.865 MHz (LSB) on 
Thursdays at 2300 GMT. You will find 
several computer-phreaque/amateurs there. 


Carl K Zettner, WSHFG 
108 Moss Dr 
San Antonio TX 78213 
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HUMANE COMPUTING? 


| am working on a survey of the human- 
istic use of computers and would like to get 
in touch with other people who are inter- 
ested in this field. | want to learn about 
what can, and is, being done to make the use 
of computers as humanized as possible. More 
specifically, | want to know: 


@ What are the potentially humane 
applications of computers? 

* What are the important ingredients in 
humanized computer systems? 

@ What is currently being done in the 
field of humane computing, both in 
terms of theory and practice? 

€ Which individuals and groups are 
actively doing this work? 

* What are their particular goals and 
objectives? 

е What are the results so far? 

@ What are the major factors deter- 
mining their successes and failures? 


| would like to hear from anyone who 
can contribute to answering such questions. 
They should write to me describing their 
thoughts, fantasies, plans and experiences 
related to the humane use of computers. 
Besides corresponding with people, | hope to 
actually visit and talk to as many contacts as 
possible. All the material | collect in this 
way will go towards the publication of a 
survey of humane computing. 


Andrew Clement 
789 W 18th Av 
Vancouver BC Canada V5Z IWI 


Humanistic needs some precision іп 
definition, but it will be interesting to see 
what you find. Readers interested in 
working with Andrew are urged to 
correspond. 


MORE COMMENTS ON 
COMPUTER TYRANTS 


| am a student at San Bernardino Valley 
College and am majoring in computer en- 
gineering. Recently, | was leafing through 
some back issues of BYTE that had been 
given to me by a friend. | came across an 
article in the February 1976 issue by Ed 
Rush entitled "Could a Computer Take 
Over?" [page 76]. 

In his article, Mr Rush points out all the 
speculation that various science fiction 
writers of today had written into their 
stories about the probabilities of a computer 
taking over some or all of future society. He 
suggested that all those who have any 
knowledge of the operation of an informa- 
tion processing system would be the first to 
confess this point. Not true. 

| have only been working with computers 
for two years, but | have also been an avid 
science fiction fan. The idea of the computer 
as a world dictator makes me think of the 
naiveity of modern society. Those who do 
not want society to progress to an easier 
more controlled future have set the 
computer up on a pedestal as the ultimate 
enemy. Science fiction writers have taken 
this concern and have written upon it. 

The true enemy is not the computer. The 
same people who tend to put down the 
computer are precisely the same people who 


Only $59.95 
Assembled 
Tested 


can appreciate its power. They are not afraid 
of the computer itself, but are afraid of 
those who control the computer. 

The computer operators and program- 
mers of the future will contro! the world, IF 
world power goes to the computer. 


Richard G Castle 
21951 Vivienda Av 
Colton CA 92324 


The neat thing, though, is so many 
different makes and models of computers 
doing most of the computing for individuals! 
Try to make that situation into a tyranny. 


SUPER STAR TREK: TREK76 


BYTE is fantastic and I’m now in the 
process of scrounging up enough money for 
a subscription. In your January 1976 issue 
there was a letter from Richard Wexler and 
he wanted info on STAR TREK programs. | 
have almost all the bugs out of an advanced 
game called TREK76 which should be just 
what he wants. 

TREK76 is written in standard FORT- 
RAN so it should run anywhere. Commands 
are entered in English sentences and the 
game is semi-real time; the Klingons attack 
and have the same armaments as the Federa- 
боп. Once all the bugs are out of it 
(hopefully over the next few months) 


4Kx8 Static Memories 


FINALLY - A CASSETTE INTERFACE THAT WORKS! 
The PerCom СІ-810 


Easily connected to any computer 9% 
'Kansas City' Standard 
Little or no software required 9 

* Operate 2 tape units simultaneously 


PerCom Data Co. 
4021 Windsor, Garland, Texas 75042 
(214) 276-1968 


PerCom — ‘peripherals for personal computing’ 


CERTIFIED TAPE 
огил 20-300 


TREK76 will be one of the best STAR 
TREK games around. Anyone interested 
should contact me (school address is: Box 
5739, University of Rochester, Rochester 
NY 14627 from September to May). 

I’m a game freak so anyone with games to 
exchange just let me know. Also, [m look- 
ing for a listing of a BASIC game called 
TREK73. 


Dave Warker 


SOME THOUGHTS ON 
"IGNORANCE IS BLISS" 


The “Ignorance Is Bliss" television drive 
circuit (July 1976 BYTE, page 38) looks like 
a simple answer to a common need. 

However, be sure to check whether the 
television circuitry is isolated from the pow- 
er line. If not, use an isolation transformer 
for the television at any time that it is 
connected to the terminal. Otherwise, plug- 
ging in the television the wrong way will put 
115 volts AC across the electrolytics if the 
logic supply is properly grounded, and will 
put 115 volts AC on the logic ground if it 
isn't connected to an external ground. 

Also be sure that your television antenna 
has a good lightning arrester to take care of 
the voltage surges caused by nearby lightning 
strikes. This is especially important because 
the electrolytics cannot withstand as much 
voltage as the small, high voltage capacitors 
you could use with an RF modulator. 


1/O Boards 


An 8-bit parallel interface 
Load a 1k byte program in 40 seconds 
Easily upgraded to 218 byte/sec 

* 18 page Instruction Manual 


NENNEN 
m 
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After you make certain that you are 
ready to use the terminal safely, you might 
consider that electrolytics aren't known for 
especially good high frequency character- 
istics. If you get a horizontal smear in the 
display, put a small (0.01 uF or so) bypass 
capacitor in parallel with each electrolytic. 


Robert F Miles 
242 Abingdon Rd 
Lenoir NC 28645 


П 


Thanks for chipping away at “ignorance.’ 


NEEDED: BENCHMARK COMPARISONS 


One question which | have had for a long 
time concerning microcomputers is through- 
put. 1 have been using a PDP-8/E now for 
quite a while. Many of my programs (such as 
LIFE) were limited by speed. It seems to me 
that the 8 is considerably faster than many 
micros; but there are other things which | 
cannot adequately compare. For instance, 
there seems to be а lot more ways to address 
memory in a 8080 (or Z-80). How do these 
chips compare, in “benchmark” programs, 
to the minis? ` 

How fast can the BASIC software for the 
8080 count іп a loop, such as [=1 to 20000? 
The PDP8/E, under the TSS timesharing 
system, managed it in about 20 to 40 
seconds. Another computer | have used, the 
HARRIS Slash Four, did 1=1 to 100000 in 


1702A* $8.50. 8223 $3.00 


$5.95 
$4.00 
$2.80 
$2.00 
$1.25 
$5.00 
$6.95 


MB-1 Mk-8 board, 1 usec 2102 or eq. I/O-1 8 bit parallel! input & output ports, 
common address decoding jumper 


PC Board. . $22 Kit ....... $100 Ж : 
selected, Altair 8800 plug compatible. 
MB-2 Altair 8800 or IMSAI compatible Күре, ts $42 PC Board only. А $25 


switched address and wait cycles. 1/O-2 1/О for 8800, 2 ports committed, 
PC Board. . $25 Kit (1usec) . . $112 pads of 3 more, other pads for EROMs 
Kit (91L02A or 21L02-1)...... $132 UART, etc. 

MB-4 Improved MB-2 designed for 8K | Кїї... $47.50 


“piggy-back" without cutting traces, Misc. 
PC Board Altair compatible mother board 


Kit 4K 0.5 usec . . 15 sockets 11"x1172" 
Kit 8K 0.5 usec Altair extender board 


Мв-3 1702A's EROMs, Altair 8800 & | 100 Pin WW sockets ,125 
Imsai 8080 compatible switched address Шық . 
& wait cycles. 2K may be expanded to 
4K. Kit less Proms, $ 65 
2K kit .. $145  4Kkit..... $225 


$ 4,50 
$ 4,50 
$ 4.50 


MM5320 
8212 
8131 


2101 
2111-1 
2111-1 
91L02A $2.55 ММ5262 
32 ea. $2.40 1103 
Programming send Hex List 
AY5-1013 Uart 

All kits by Solid State Music 
Please send for complete líst of products 


= MIKOS 


419 Portofino Dr. 
San Carlos, Calif. 94070 


Check or money order only. Calif. residents 6% tax. All 
orders postpaid in US. Ail devices tested prior to sale. 
Money back 30 day Guarantee. $10 тїп, order. Prices 
subject to change without notice. 


PC Board only, . $25 


$ 1.95 
$59.00 | $68.00 


$ 2.25 
$50.00 
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about 15 seconds. At the same time it was 
supporting other users. 

Simply counting makes for lousy bench- 
mark programs, though. | would appreciate 
an article on the subject. 


James Wiebe 
208 N Jefferson 
Hillsboro KS 67063 


The benchmark slot has not been 
adequately filled with articles in BYTE, as 
James’ letter points out. Authors take note: 
A general background article on the theory 
and validity of benchmarking, applied to 
microprocessor technologies, would be most 
useful to readers in evaluating processors. 


DOCUMENTATION NEEDED 


| am searching for a company that was at 
one time located in Derry, New Hampshire. 
The name of the company was/is Data Input 
Devices Inc. 

They built a TV typewriter terminal unit 
that my friend (8800 Altair owner) bought 
at a hamfest. 

We are hoping to get schematics from 
either the company (if it still exists) or from 
a prime consumer of the unit if we can find 
that out. 

Any leads will be much appreciated. 


Tom McMurtrey 
WA4FYN 

244 Roosevelt Av 
Florence AL 35630 


Can any readers help here? 
A QUESTION OF COMPATIBILITY 


Is it possible to successfully use the Altair 
16K static RAM (215 ns) in the IMSAI 
8080 in lieu of the IMSAT 4 К RAM and still 
obtain the a) low power, b) memory (1K 
blocks) write protect, c) power fail memory 
save benefits? 

How about the MIKRA-D 16 K RAM in 
the IMSAI 8080? 

| am seeking workable solutions to con- 
figuring a 64 K processing without using up 
(16 of 22) all the available slots while still 
getting the advantages offered by the proces- 
sor manufactures on their smaller memory 
boards. 


А B Clark 
15425 SW 88th Av 
Miami FL 33157 


Has anyone in the BYTE readership tried 
this particular combination of modules? We 
have no data with which to give an answer to 
this question. 


NEED AN ACCURATE HP-45 TIMER? 


| have long been interested in the timing 
capabilities of the HP-45 and have watched 
for information on it. Last month EDN 
published how to add the crystal to make an 
accurate timebase, and said that HP was 
selling crystals for $14 plus $1 for shipping. 
Upon contacting HP 1 found they have 
them, but you have to know somebody. 
After some research and a few long distance 
phone calls | was able to make some 
arrangements to obtain a supply of crystals 


from the manufacturer. | would like to make 
these available to interested BYTE readers 
for $12 plus $1 shipping. 

Enclosed is the article from EDN and also 
an explanation | received that differs slightly 
on how to install the crystal. This may be 
because of the two different versions of 
HP-45s. | have hooked one up for someone 
using the HP sheet and it works fine. The 
other way may work as well. | shall try it 
soon. 


Mark S Egbert 
1514 S 320E 
Orem UT 84057 


PHOBIA 


One of my pet phobias is people who 
short out capacitors. In BYTE #12, page 96, 
figure 1, the keyboard switches directly 
short out the 1 uF capacitor and this is, no 
doubt, the cause for the “‘oil film" referred 
to in the last paragraph on page 97. Just 
imagine the surge current that flows when a 
switch is closed. This is not good for the 
capacitor and is positively damaging to the 
Switch. 


Webb Simmons 
1559 Alcala PI 
San Diego CA 92111 


Well, maybe. А capacitor of ТЫР, 
charged to 5 volts, holds О=С* 
V=5 * 10 ** —6 coulombs of charge. If the 
contact closure produces a spark, which can 
be detected on an AM radio, then it is a safe 
bet to say that the contact event takes place 
in from 10 to 100 microseconds (in order 
for significant hurmonics to be detected in 
the 500 KC to 1500 KC AM radio band). 
Thus 5 microcoulombs are being discharged 
at an average rate of 0.5 ampere in the 10 
microsecond case, 50 milliamperes in the 
100 microsecond case. Peak values might be 
considerably higher, possibly pitting the 
contacts. This off the cuff analysis does not 
take into account the effect of the resistance 
in wires and capacitors, and is conditional on 
these contact conditions being able to 
generate measurable RF from а sparking 
contact, 


KUDOS, GRAPHICS, STATE OF THE ART 


This letter of mine is in response to 
several items in your july letters column 
{pages 90-94] : 

1. | would also recommend James Elec- 
tronics (ICs). Delivery is usually less than a 
week. 

2. With regard to the graphics display 
circuits: 

a. For the circuit you asked for | would 
recommend that consideration be 
given to making it 256 X 512, allowing 
it to simulate a standard 16 X 64 
character terminal or display module. 

b. Any such circuit would not be inex- 
pensive. It is not clear to me whether 
you are asking for a plug-in module, or 
a stand alone device to communicate 
through an IO port. Mr Hyde defi- 
nitely wants a stand alone device. | 
doubt that a module would be notice- 
ably cheaper than buying a Cromemco 
Dazzler (TM). The savings due to 
giving up color would be easily offset 
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by the additional addressing, and they 
can get quantity discounts that the 
individual hobbyist cannot. 

A stand alone device would cost more 
yet: The electronics would be more 
complex, possibly justifying a dedi- 
cated microprocessor, and even worse, 
you then need a power supply, cables, 
a box and all the other things which so 
rapidly run up the cost of a good 
looking (and reliable) homebrew pro- 
ject. 

3. | am afraid that the hobbyist is never 
going to get noticeable quantities of true 
state of the art items. Announcements in 
magazines such as Е/есігопіс are at least six 
months (if everything goes well, which it 
usually doesn't) ahead of volume deliveries. 
After that, there is at least another six- 
month wait to design an item into a hob- 
byist kit, and get that into production. The 
probability approches 1 that one of these 
steps will meet an unforeseen delay of at 
least 90 days, such as the capacitor shortage 
of a few years ago. 

Finaily, the cost of truly new items (4 K 
RAMs, not cheaper floppies) is far more 
than the hobbyist can afford. 1 K RAMs 
Cost a darn sight more in thousand quantity 
five years ago than we are currently paying 
for one. | worked with 93410s (256 bits, 
50 nsec) when they were $20 apiece in 
hundreds, and they're now $1.95 in onesies. 

As this happens to 4 Ks we'll start seeing 
them. 

Anyway, congratulations on a worthwhile 
and continually improving magazine. 


Frank Richards 
414 Bradford Way 
Norristown PA 19401 


AUTHORS, TAKE NOTE 


Ever since BYTE #1, I’ve been waiting 
for more conceptual articles like “Write 
Your Own Assembler." How about some 
more articles оп... 

* Random number generators, and the 
testing and demonstration of random- 
ness in various random number genera- 
tion schemes. 

€ Executive software structures, what 
kinds exist, advantages and disadvan- 
tages of various methods, etc. 

ә Human engineering factors апа 
pointers concerning computer peri- 
pheral placement, panel and console 
design, etc. 


James F Gentry 


NEEDED: USED COMPUTER INFO 


| am a charter subscriber to BYTE. ! have 
enjoyed every issue from #1 to date. Your 
publication has expanded greatly my knowl- 
edge of software. Mostly | have learned that 
| have much to learn. 

Like everyone who has been bitten by the 
computer bug, | wanted very much to have a 
system to play with. | had almost decided to 
embark on the purchase and assembly of 
either a 6800, or an 8080 system kit (with 
faint echos and moans from the wife), when 
| chanced upon the purchase of a full blown 
16 bit computer through a local government 
surplus outlet. The only problem with this 
was that some of the interconnect cables 


уеге missing and there was МО 
INFORMATION. 

The unit | have is a DATA 620 system, 
housed in two 19 inch wide, 6 foot tall 
racks, It consists of a CPU, two power 
supplies, a bootstrap loader panel, tape IO 
and reader (used to load the program, | 
believe), a general purpose lO (purpose 
unknown), and two core memory units 
(organized as 2048 words of 16 bits each 
unit, 4 K total CORE). 

This unit was in use at the Manned 
Spacecraft Center in Houston (use un- 
known). | believe it was in use circa 1961. It 
was probably built around that time because 
it uses all discrete logic, no integrated 
circuits. |t uses —10 volt load source, +6 volt 
logic bias. The machine was made by а 
company called Data Machines Inc, Newport 
Beach CA. This company is/was a subsidiary 
of a company called Decision Controls Inc 
(address unknown). As you can see | have 
more questions than data. Although a 
chance investment, | thought it a good buy. 

It is my deep hope that you or one of 
your readers might be able to supply me 
with some information. | have written to 
Newport Beach c/o the postmaster, but no 
such company is in existence out there, and 
no forwarding address. Any help you can 
give me in this matter would be greatly 
appreciated. 


Godfrey C Leggett 
185 Marceline 
Beaumont TX 77707 


We publish this letter in the hope that 
some reader will provide information helpful 


to Mr Leggett in his pursuit of a personal 
system. 


VA COMPUTERS NEEDED 


| have recently become aware of the 
world of personal computing and am an- 
xious to become part of it. Like many 
others, however, | am not prepared to lay 
out the money for a microprocessor, ІО 
device, memory, permanent storage capa- 
bility, etc. If there were microcomputer kits, 
as there are television kits, which were part 
of a Veterans Administration approved cor- 
respondence course, the door would be open 
for thousands more. Could you put me in 
touch with anyone having such a course or 
spread the word to the microcomputer kit 
industry about this seemingly untapped, 
eager pool of potential customers? Thanx. 


Steve Packard 
44 S Greenfield Av 
Hampton, VA 23666 


ІВМ SELECTRICIO 


The letter from Dr James Lang in the 
August BYTE on the desirability of using 
the IBM typewriter for a console device hit 
close to home — after | design the interface 
for this Selectric 735 I’m typing on, that's 
what 1 will have. Please note — this isn't just 
any old Selectric, but the one with all the 
solenoids and switches already under it. 
These machines are now available on the 


Continued on page 75 


THE BEST IS NOW*T 


MFE's 250B Digital Tape Transport 
Offers a 32000BPS Data Transfer Rate 


OPTIONAL 
8 BIT PARALLEL 
I/O INTERFACE 


ANSI/ECMA 
COMPATIBLE 


e 15,000 Hr. MTBF e 1 Year warranty e Two moving parts 
е Reel to reel e Constant tape tension and constant tape 
speed — servo controlled e £5VDC operation e Guaranteed 
cassette interchangeability e Up to 800 BPI e Read after 
write heads е Bi-directional read/write operation ө Size: 
4,39 X 5.46 X 2.42 e A few $525, a hundred $325 e 
Call or write Jim Saret 


*Recent survey among leading buyers named MFE number 1. 
Source on request, Over 15,000 in the field. 


Keewaydin Drive 
Salem, N.H. 03079 
Tel. 603-893-1921 
TWX 710-366-1887 


MEE CORPORATION TELEX 94-7477 


Computer 
Peripherals 
available from 
PolyMorphic 
Systems 


The Video Terminal Interface circuit 
card generates 16 lines of 32 or 64 
characters (depending on option) on а 
standard video monitor or slightly 
modified TV set. Characters are stored 
in a 1/2 or 1K RAM on the video board. 
Display capability includes graphics and 
text. Text includes all keyboard 
characters including upper and lower 
case, іп a clear, highly readable 7 x 9 dot 
matrix font. Graphics characters are 
made up of 2 x 3 grid in each character 
position, allowing for display of a 48 by 
up to 128 contiguous grid on a TV 
screen. The entire screen may be 
updated in 20 msec. The Video Terminal 
Interface circuit card also includes an 8 
bit parallel keyboard input port, allowing 
the board to function as the complete 
computer interface. 


The Video Terminal Interface includes 
standard software, allowing scroll and 
page modes, insert/delete, and full 
cursor control. Literature covers kit- 
building, testing, trouble-shooting, and 
software. 


The PolyMorphic POLY VTI is the only 
* Altair-compatible" video terminal 
interface with keyboard input port and 
full graphics. 


Prices: 32 character line kit — $185 
64 character line kit — $210 
Assembled $280 


Other peripherals available from 
PolyMorphic Systems includes an 8K 
RAM board, a versitile prototyping 
board (“The Ideaboard”), andan Analog 
Interface. 

All prices and specifications subject to change without 
notice. Prices are USA only. California residents add 


6*6 sales tax. Prepaid orders shipped postpaid. 
BankAmericard and Master Charge accepted. 


PolyMorphic 
Systems 


737 S. Kellogg Avenue, Goleta, Ca. 93017 
(805) 967-2351 
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The first 


complete small 


computer. 


As you thumb through this maga- 
zine, you'll see a lot of ads for small 
computers. For $600 you can find a pretty 
good box with a power supply, four slot 
mother board, CPU module, and all the 
expected lights and switches. 

But you know what? It won't work. 

That's because in order to make the 
computer go you have to buy memory — 
normally both read-write (RAM) and read- 
only (PROM), interfaces to the outside 
world (parallel, serial, and cassette), 
keyboard, video display module, and 
software. 

Add this all up and it's going to cost 
you at least $1,400 for a complete system. 

Got the picture? 

Now listen to this. The remarkable 
new Sol-20 Terminal Computer will give 
you all of the above... plus more!...as 
standard equipment for just $995, in kit 
form. This is because the Sol-20 — like no 
other small computer — was designed 
from the ground up to be complete. 

Here's what the Sol-20 includes as 
standard equipment: 

• 8080 microprocessor. 

* Video display circuitry. 

* 1024 words of static, low-power RAM. 

* 512 words of preprogrammed PROM. 

* Custom 85-key solid-state keyboard. 

* Audio cassette tape interface. 

* Both parallel and serial interfaces and 
connectors. 

* Power supply. 

* A beautiful case with solid walnut sides. 


• Software that includes a preprogrammed 


PROM personality module and a cas- 
sette with BASIC-5 language plus two 
sophisticated computer video games. 

• Full expansion capability with all S-100 
bus (Altair/IMSAI/PTC bus) products. 
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It's a handsome terminal or 
computer that will even look good in your 
living room or office. Small systems start 
at just $475. 


Full expansion capability 

The Sol-20 system can be tailored 
to your applications using the complete 
line of peripheral products from Processor 
Technology. These include the video mon- 
itor, audio cassette and digital tape sys- 
tems, dual floppy disc system, memories, 
and interfaces... plus all other peripherals 
compatible with the S-100 bus. 

The Sol-20 greatly simplifies the 
computer-buying process. It’s a splendid 
package that will excite both present and 
prospective computer owners. 

Our brochure tells all. Write for 
it today. 

Processor Technology, 6200 Hollis 
Street, Emeryville, CA 94608. 

(415) 652-8080. 
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5601-20 expandable 
system. 
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Processor Technology 


HARDWARE AND SOFTWARE 
Now available from the following dealers 


California 


Applied Computer 
Technology 

2465 Fourth Street 
Berkeley, CA 94610 


The Byte Shop 
1514 University Ave. 
Berkeley, CA 94703 


The Byte Shop 
2559 South Bascom Ave. 
Campbell, CA 95008 


The Byte Shop 
2227 El Camino Real 
Palo Alto, CA 94306 


The Byte Shop 
509 Francisco Blvd. 
San Rafael, CA 94901 


The Byte Shop 
2989 North Main St. 
Walnut Creek, CA 94596 


The Computer Store 
of San Francisco 
1093 Mission Street 
San Francisco, CA 


Florida 


Microcomputer 

Systems Inc. 

144 So. Dale Mabry Hy. 
Tampa, FL 33609 


Illinois 


The Chicago 
Computer Store 

517 Talcott Road 
Park Ridge, IL 60068 


itty bitty 

machine co., inc. 
1316 Chicago Ave. 
Evanston, IL 60201 


Indiana 


The Data Domain 
111 South College Ave. 
Bloomington, IN 47401 


New Jersey 
Hoboken Computer 
Works 

56 Second St. 
Hoboken, NJ 07030 


New York 

Audio Design 
Electronics 

487 Broadway, Ste. 512 
New York, NY 10013 


The Computer Corner 
200 Hamilton Ave. 
White Plains, NY 10601 


The Computer Mart 
of Long Island, Inc. 
2072 Front Street 
East Meadow, L.I., 
NY 11554 


The Computer Mart 
of New York, Inc. 
314 Fifth Ave. 

New York, NY 10001 


Synchro Sound 
Enterprises 

193-25 Jamaica Ave. 
Hollis, NY 11423 


Oregon 


The Real Oregon 
Computer Co. 

205 West 10th Ave. 
Eugene, OR 97401 


Rhode Island 


Computer Power, Inc. 
M24 Airport Mall 
1800 Post Road 
Warwick, RI 02886 


Washington 


The Retail 
Computer Store 
410 N.E. 72nd 
Seattle, WA 98115 


Wisconsin 


The Milwaukee 
Computer Store 
6916 West North Ave. 
Milwaukee, Wl 53213 


Processor Technology Corp. dealerships are available 
only to qualified retail computer firms. 
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Continued from page 71 


used market for prices ranging from $500 to 
$1000, depending on model and condition. 
This machine cost $1 K, as it was a new 
machine bought from one of the used mini 
houses. | am working on an interface to 
connect this gadget to my IMSAI 8080. 

This interface will be compatible with 
most 8080 software; that is, the code will be 
ASCII-7, with port selection and flag bits 
jumper-selectable. | also intend to make the 
interface compatible with most, if not all, of 
the available options for the 735 and 731. 
(The 731 is the narrow version of the 735, 
with an 11 inch writing line instead of 15 
inches.) | have heard that the 735 has been 
replaced in the IBM lineup by something else 
— this may be the reason they are showing 
up in the used computer shops. Whatever the 
reason, it's nice to be able to get good 
machines at reasonable prices. 


Philip M Spray 
3006 N E 26th 
Amarillo TX 79107 


Avoid mechanical kluges — buy one with 
the actuators built in. 


ARTICLES NEEDED: GETTING SENSOR 
DATA INTO COMPUTERS 


| have really enjoyed BYTE, especially 
articles such as the Suding and Lerseth 
contributions in the July issue. | wonder if 
you will be doing some articles on connec- 
tion to the analog world. This seems to be an 
important region that has been shortchanged 
in your publication. 

| would like to see transducer data such 
as thermocouples, thermisters, and RTDs for 
temperature measurements; strain gauge data 
for stress, pressure, etc; optical and/or 
magnetic transducers for velocity, etc. | 
would also be interested in explanations 
about signal conditioning (bridges, channel 
amplifiers, zero set and scaling amplifiers), A 
to D and D to A techniques and methods 
(such as ramp DAC, successive approxima- 
tion, and tracking A to Ds). For a micro, or 
any other computer, to "feel" what is going 
on in the physical world, these sensors that 
collect ignition pulses, temperatures, load 
pressure data, etc, are very important. 


C Southard 
2519 Meadowbrook Dr SE 
Cedar Rapids 1А 52403 


TIMMMBBERRR! 


Enclosed you will find my check and 
subscription to BYTE. I’ve only been able to 
find a few copies in this area and | found 
each of them very interesting and infor- 
mative. Having just gotten our Altair 8800 
up n running [ thought you and your readers 
might be interested in hearing about its 
unique application. Presently, we are using 
an 8800 at this Lumber Mill to monitor our 
daily production. We have a lumber sorting 
machine that incorporates CMOS technology 
in its control system. Through the use of 
limit switches the machine measures every 
board as it sorts it coming out of the 
sawmill. It displays the measurement data on 
a set of seven segment LEDs built into the 
control panel. That is where we tapped in 
our interface, designed for us by Warren 


All-new Phi-Deck; 
precision remote controlled 
cassette transports starting at 


under $1OO! 


Featuring: 

Re-engineered precision parts 
New cast frames 

4 motor reliability 

Remotely controlled 

Precise, fast head 
engage/disengage 

* Quick braking 

* Various speed ranges 


. 4... 


Electronic packages for control or read/write 


For application In: 6. Data duplicating 
1. Micro processing 7. Security/automatic warning 
2. Data systems 
recording/logging/storage 8. Test applications 
. Programming 9. Audio visual/education 


. Instrumentation 10. Hi-Fi 
Industrial Control 11. Others 


3 
4 
5. 
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TiipleI A Division of The Economy Co. 


ҮП 1901 North Walnut P.O. Box 25308 UU 
Oklahoma City, Oklahoma 73125 (405) 521-9000 


| О | am interested in application no. - 


O Have Representative call О Send application notes 


Name — Title 
Company Name - 

Address _ 
City  біе Zip 


Phone Number __ 
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KENTUCKY FRIED 


COMPUTERS 
бее, >6 ж A 


А new retail computer store in Berkeley, California. 
We sell and service small computers for personal, 
educational, and business use, both in kit and 
assembled form. Many items are at substantial 
discounts from manufacturer's list prices. Special 
prices on complete systems. We can help you "put 
it all together" 


“IMSAI-Computers, memory, interfaces & peripherals 
Processor Technology-Memory, interfaces & software 
Lear Seigler-ADM3 Terminal kit. 

*Polymorphic Systems-Computers, memory & interfaces 

*Cromemco-TV Dazzler, Bytesaver and A/D-D/A 

*Apple-Apple-1 computer 

* Morrow's Micro Stuff-Cassette interface 

*Oliver Audio Engineering-Paper tape reader 


*Starred items available by mail order at 10% 
discount from manufacturer's current list prices. 
For prompt delivery, send money order or cashiers 
check plus 2% shipping & handling. Personal 
checks require 3 weeks processing. Calif. res. add 
sales tax. Minimum order $80.00. 


KENTUCKY FRIED COMPUTERS 
2465 FOURTH STREET 
BERKELEY, CA 94710 


TELEPHONE: (415) 549-0858 


A COMPUTER IN EVERY POT 
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Stardup, a partner-technician with Micro- 
Computer Systems Inc, which is based in 
Tampa FL. 

The interface converts the TTL at the 
display to serial and relays the data via 
20 mA loop back to the office where the 
computer is located. Currently, we are using 
a video display with data in memory being 
dumped on cassette every hour, in case of 
power failure and loss of memory. A hard 
copy printer is on order. In the future І plan 
to scan the logs just before they are cut, 
compute that versus what comes out at the 
sorter, thereby giving me a readout of the 
recovery | get out of each log. Thought this 
might be of interest to you. Keep up the 
good work. Your magazine is refreshing! 


Tommy Staten 
HC Hodges Lumber Co 
Panama City FL 32401 


THE EMULATION BLUES 


| read with interest Don Keek's letter in 
the August issue of BYTE concerning the 
emulation of a PDP-8 instruction set on one 
of the popular microcomputers. As the 
author of several emulation programs for 
various computers, | feel obliged to com- 
ment on my experiences. | have written two 
emulators for the PDP-8, one implemented 
on the Control Data 6400, a 60 bit scientific 
computer, the other on the PDP-8 itself. The 
self emulation has value in a trace-type 
debugger for programs and peripheral inter- 
faces. The CDC 6400 implemented emulator 
was used to teach minicomputer program- 
ming techniques to a large number of stu- 
dents in a batch environment. 

As Don mentioned in his letter, memory 
and execution time are definite bottlenecks 
in emulating one machine on another, parti- 
cularly when the characteristics of the two 
machines are different. | would suggest that 
a PDP-8 emulator program written on an 8 
bit micro would be hard put to achieve 
average execution times of less than 20 times 
the execution time on the PDP-8 itself. 
Memory requirements would be about 10K 
bytes for emulation of a 4 K PDP-8. 

The higher level languages supported on 
4K PDP-8s are almost all interpreters 
(FOCAL, BASIC, and 4K FORTRAN for 
sure). The further degradation of an inter- 
pretive language by at least a factor of 20 
would be quite noticeable, if not annoying. 
[Total degradation: 400 times slower.] 

Quite a few PDP-8 programmers have 
made use of “programmed delays"; that is, 
looping a specified number of times to 
achieve a specific time delay, or to deter- 
mine whether a peripheral has stopped 
sending data. Such loops will obviously not 
emulate faithfully. 

| recommend that anyone interested in 
writing an emulator acquire the CPU 
diagnostic programs for the machine being 
emulated. This will be an invaluable aid to 
debugging and benchmarking. 


R A Schottland 
7040 N Sheridan Rd 
Chicago IL 60626 


DIVIDE AND CONQUER (INSTABILITY) 
"Why Wait?" by Suding //ш/у 1976 


BYTE, page 46] is very interesting. The 
ratio of his two frequencies is 1 to 1.4. Many 


of us do not have access to counters or 
oscillators. Crystals and common chips are 
Cheap. 

If a 1 MHz crystal oscillator is divided by 
32, the result is 31250 Hz. If this is sent to a 
divide by 14, and a divide by 10 chain, then 
the results are 3125 and 2232 Hz. Switch 
between the two with an inverter driven by 
the data, gate it into an integrator, and one 
gets the triangular wave to drive the tape 
head. This should eliminate stability prob- 
lems in the two frequencies and should still 
be within the telephone line frequencies for 
acoustic couplers for phone transmission. 
Many of us would like to be able to use 
Cheap cassette recorders if possible. Suding 
implies that his filters can be tuned over at 
least one octave, and maybe two. If this is 
true, R25 and R26 should be reduced in 
value and padded with resistors. 

However, if considerable variation is pos- 
sible in frequency, and a long period of each 
tone is put on the tape before the program, 
say 30 seconds each, and a voltmeter were 
connected to 1С37 pin 7, then the filters 
could be tuned (max volts out) to the 
frequencies actually present, and the only 
requirement on the cassette is that the speed 
be within plus or minus five percent for the 
time the program is running. 

| regret that 1 do not have the equipment 
to try this system, but | am willing to discuss 
it with anyone. 


Cecil H Royce 
255 S Marion 
Oak Park IL 60302 


The point about 3125 Hz being com- 
patible with the phone network may be 
debatable; would any telephone engineers 
care to elaborate? There is a standard set of 
modem frequencies available, in integrated 
circuits yet. 

A point about standards which should be 
repeated: The way to approach the subject is 
to document what is being done by manu- 
facturers, with discussions about the virtues 
(or faults) of the systems. This way, the user 
(and other manufacturers) are kept aware of 
the state of the art as practiced in manufac- 
turable systems. So far, there are two tape 
interface definitions documented in BYTE 
for audio use; more will come. 


SOME THOUGHTS ON MISCELLANY 
AND TAPE MODULATIONS 


| just finished reading the August issue of 
BYTE pretty much cover to cover and as 
usual found it interesting. | wanted to write 
last month but didn't get around to it and I 
have a few tid Bits (BYTES) of information 
and complaints to throw out. 

One minor bug in BYTE is | wish you 
guys would put the issue date at the bottom 
of each page. It makes it rather hard to 
reference some of the older articles that | 
Xeroxed from a friend's earlier issues. 

| thoroughly enjoyed “Jack and the 
Machine Jive" by Bob Grappel. It's been a 
while and i honestly forgot how hashing 
works. It was a very interesting and infor- 
mative refresher course. | am presently 
giving some thought to a "general purpose 
assembler," one that can be used to assemble 
code for more than one micro-widget simply 
by changing the lookup tables. 


76 


Martin Buchanan's Video Disk article and 
Burt Hashizume's writeup on the Zilog Z80 
were also very interesting. Тһе 280 will most 
certainly become the most popular micro as 
soon as the price drops to the same magni- 
tude of power as the 8080 and 6800. 1 really 
like the maskable and unmaskable interrupts 
and arithmetic shifts features of the 6800 
and Z80. Does anyone know an easy way to 
do an arithmetic shift right using the 8080? 
But Zilog has outdone themselves with the 
bit addressing, block transfer (flush instruc- 
tion) and search instructions. The mode 2 
interrupt is also the way 1 prefer to do 
vectored interrupts, but there are also two 
other ways (modes) if you are fussy. 

John Baird's comments on the informa- 
tion revolution are beautiful, We all know 
that BYTE can do what no technical trade 
journal can do: Convey practical, down to 
earth, State of the Art, easy to understand 
ideas. The technical journals have mostly 
become a place for doctorate fellows to 
shelter a highly technical snow job just to 
meet their degree requirements. Decipher 
and remove the high level math and the guy 
usually has little information to pass on. 
BYTE is the source of innovative design 
ideas (hardware and most certainly 
software). 


| was a little upset at Dr Suding's "Why 
Wait? Build a Fast Cassette Interface” article 
in the July issue. His article would lead you 
to believe that frequency shift keying (FSK) 
is the only way to fly. Of course any article 
written by an author writing about a pro- 
duct he is trying to sell is usually a little 
biased. Dr Suding is obviously an analog man 
with his filters and tune up notes. Tweek 
this ... Tweek that. Sure Manchester em- 
ploys “harmonically related frequencies," 
and frequency discrimination techniques just 
won't hack it. He has one good point: 
“Imagine reading 300 baud for 15 minutes 
to discover a noise pulse had destroyed data, 
requiring re-recording.” This problem exists 
no matter what recording technique is used. 
The best solution is to use short data 
records; say 64 bytes (also a good format for 
listing). Then if your cassette has backspace 
capability you simply back up one record 
and try again instead of a complete rewind. 
Using character, record and file gaps is a 
worth while consideration for a well man- 
aged file system. Try to keep the record size 
fixed to whatever corresponds to your single 
line list device, at least the source state- 
ments. A file is a collection of records, either 
a program or subroutine. 

Back to FSK versus PSK: First of all 
Manchester is really phase shift keying (PSK) 
using square waves instead of sinusoids. Both 
FSK and PSK require an extra start bit or 
sync bit equal to a one. Even using the 
Suding FSK there is no physical way to go 
from DC (no flux changes at the start of a 
cassette record) to a 2975 Hz signal, a 0 
without first going through 2125 Hz, a 1. Dr 
Suding needs to review his Fourier trans- 
forms if he believes that only 2125 and 2975 
Hz frequencies exist in the FSK waveforms. 
The PSK (Manchester or similar) method 
requires the first bit sent to be defined 
arbitrarily as a 1. From thereafter one 
definition of Manchester may be a zero 
phase shift meaning no change in the state of 
the data (ie: a 11) and а 180 degree phase 
change in the signal means complement the 


data state (ie: 10). Another definition is a 
low to high transition in the center of a bit 
cell is a 1 and a high to low transition at the 
center of a bit cell is a 0. In any case the 
Manchester code consists of two pulse 
widths: full bit cell and half a bit cell width. 
A digital demodulator needs then to decrimi- 
nate a 1/2 bit cell pulse from a 1 bit cell 
wide pulse. This is usually done with one or 
more delay elements (one shot or delay line) 
set at a 3/4 bit cell reference point. The 
Manchester or similar codes potentially have 
a faster data rate than FSK. 

For example, say the upper recording 
limit on a cassette was 2 kHz. The Man- 
chester data would be recorded at a 
1000 bits per second rate. The two pulse 
widths of 1 msec (half bit cell) and 2 msec 
(full bit cell) would be involved. One bit cell 
only requires 1/2-1 kHz cycle or 1-2 kHz 
cycle per bit cell. The FSK technique using 
filters | doubt seriously would be able to 
respond to a 1-2 kHz cycle pulse. It would 
certainly require a bunch of 2 kHz cycles 
(the modulating frequency is obviously got 
to be less than the carrier). Even if it could 
detect a 2 kHz signal in 4 cycles, say, then 
Manchester beats the FSK 4 to 1 in re- 
cording density (speed). 

Also since there is always at least one flux 
change per bit cell using Manchester or 
similar self clocking code, the demodulator 
can correct for variations in tape speed by 
adjusting its 3/4 cell reference either using a 
phase locked loop (PPL) (see “Improved 
Cassette Interface Circuit" by Hal Mauch, 
page 8, April 1976 BYTE) or a program- 
mable counter or even a software tracking 
routine. 

A software routine could count the num- 
ber of elapsed clocks since the last flux 
change (phase detector) and decide if it was 
a 1/2 cell or fuil cell change. It could take 
this number, subtract it from what it was 
expecting for a 1/2 or full cell clock count, 
then average the error over previous samples 
(low pass filter) and make a correction 
(prediction actually) to what the next 3/4 
cell reference should be. The routine would 
be realizing what is called a sampled phase 
locked loop. The only readback hardware 
need only be a limiter similar to Dr Suding's. 
The rest could be software. If a data 
transmission is going on, the micro is prob- 
ably not doing anything but waiting around 
for the character to shift out anyway. 


Frank Bennett 

Hughes Aircraft Co 

Displays Lab 

Fullerton CA 92634 

One way around the tape interface 
problem is the obvious one, a point raised in 
your letter which we emphasize here: With 
the proper general purpose signal condi- 
tioning hardware to convert AC coupled 
signals into TTL digital levels and vice versa, 


domain. They are available to anyone — 
including hobbyists — at cost. These pro- 
grams include all of the common computer 
languages. They obey the instructions of 
most terminals. 

There is no need to reinvent the wheel — 
again, and again, and again. 

The above programs may be readily trans- 
lated into 8080, 6800, F-8 6502 micropro- 
cessor instructions. There are no restrictions 
on revising these programs. There are no 
restrictions on distributing them. They are in 
the public domain. 

Why don't you do yourself, your 
customers, your subscribers, and thousands 
of others a grand favor, and write for 
information from 

Documents Office 

Kiewit Computation Center 
Dartmouth College 
Hanover NH 03755 


Edward L Tottle 
2993 Yorkway 
Baltimore MD 21222 


HOW TO WIN AN ELECTION 


As a professional software engineer (a 
fancy term for a programmer), | receive a 
great many computer related publications 
each month. | am six months behind in 
reading Communications of the ACM, two 
issues behind of Computing Surveys, four 
back of Computer Design; and | don't even 
want to think of how far of Scientific 
American. But every month, as soon as it 
appears in the mailbox, BYTE gets read 
from cover to cover. 

In the free market, there is one sure way 
to show one's appreciation for a product. 
Enclosed is my renewal for three more years 
of BYTE. Keep up the good work. 


Howard L Turetzky 
HYDRA 

1575 Ivanhoe St 
Denver CO 80220 


PS — This letter was typed on an IBM 
Selectric IO writer driven by an Altair 8800, 
so blame all the typos on the computer. 


OLDE ENGLISHE 


| have been on a crusade over the past 
few years, trying to discover the true origin 
of the word "byte," but my efforts have 
been unsuccessful. | have begun to think 
that the origin is lost, but | have decided on 
one last attempt. 

Since the name of your magazine happens 
to be the very same word that has been the 
source of my frustration, | am hoping that 
you can shine some light on the origin of 
this small word. | have looked in just about 
every textbook that | can get my hands on. 

If you can provide some relief to my 
plight, it would be most appreciated. Thank 
you for your trouble. 


Thomas P Bishop 

PL/C Project Manager 
Department of Computer Science 
Cornell University 

Ithaca NY 14853 


| first ran across an etymology of the 
word BYTE іп a book | read on the ІВМ 
"Stretch" computer borrowed from an asso- 
ciate of mine at Intermetrics Inc, where | 
worked prior to founding BYTE. In that 
book, which was published in the early 605, 
а research precursor of the 1BMÍ360 series 
was being described. The “Stretch”? com- 
puter (if | remember correctly) had a large 
bit addressable memory, in which the term 
byte was an arbitrarily coined word used to 
reference an arbitrary bit string field of 
length “п”. The term at that time was meant 
as а generalized concept of a bit string 
subfield. When the 360 came out, all that 
changed, since after System/360, almost all 
published literature references 8 bit bytes. 
Perhaps a reader can supply a more defin- 
itive answer to the question of the term 
BYTE's origin, and some of the history of 
the early “supercomputer” work following 
the “second generation” transistorized com- 
puters of the late 1950s and early 
7960s....CH 


FLEXOWRITER FLEXIBILITY 


Dear SIRS, 


4891 Soncerind Он, 
Cotumsus, ©нто 43229 
31 Jutv 1976 


I see a NUMBER OF COMPLAINTS ABOUT THE LACK OF REASONABLE 
priced ТО devices AVAILABLE WHICH WILL produce нава copy. 
THIS LETTER IS BEING Typed on a Friden FLexwriter I ривсназєа 
ror $200 used. THERE ARE many avalILaBLE ғов tess. AS vou 

can SEE IT HAS ап ATTRACTIVE TYP FACE an BOTH UppeER and 


LOWER CASE,, 


IT Has а papeR Tape punch and REadER., BUT à VERY 


nearly any modulation method сап be gener- 
ated and decoded using simple algorithms. 
Several computers currently being marketed 
use such generalized hardware backed up by 
software in PROM monitors. These include 
the new Apple computer, BABY by STM 
Systems, etc. 


SOFTWARE 


роба trprst. Іт Runs asout 10 eps. ALTHOUGH IT IS NOT CONNECTER 
TO à COMPUTER ат THE DRESEDT IT наз CONNECTIONS FOR data Input. 
І( RATHER my sec ) USES IT FOR а LOT OF RED LETTER WRITING. 

I ат SURE SOMEONE CoOULd WORK OUT THE DROBLEMS OF CONNECTING IT up. 


THE DADER TADE IS а SEVEN TRACK таре. 


PIERCE 


Soon, 


People want software. There are about 


1,000 computer programs in the public ач ғ. 


Sounds like ап excellent hard copy deal. 
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USS ENTERPRISE 


Make Your 
Next Peripheral 
a Real Eye Opener 


Steve Ciarcia 
124 Hebron Av 
Glastonbury CT 06033 


Photos by Ed Russo 


Have you ever gone to a party and been 
entertained with some party game which the 
host introduced to impress his guests and 
salvage an otherwise boring evening? Ameri- 
can life is built upon a succession of gim- 
micks. We feel we have to be entertained to 
exist and cannot just have a good, dull time. 
An example is the success of television as the 
universal babysitter and now all these overly 
expensive television games. 

Excuse my “Holier Than Thou” attitude, 
but I’m no different than the rest of the 
population, including having one of those 
stupid TV games. What I’m trying to lead up 
to is to introduce a microprocessor driven 
vector graphics display controller which can 
be built for $60 or less. 
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Some history is in order. About eight 
years ago, | was at MIT for a conference and 
spent some time touring the campus. In the 
corner of one room in an otherwise deserted 
computer center was a large, intensely in- 
volved and vociferous crowd. Above the 
usual crowd noise were heard shouts of 


"Shoot your phasers now!”’, “Watch out for 
that meteorite!”, and "He's in the space 
warp!". Because | usually avoid crowds 


because of something my grandmother once 
said about the correlation between crowds, 
fleas, and bubonic plague, | fought off the 
urge to investigate further. But, after hear- 
ing, "His antimatter engines are done — blast 
him out of the sky!", and tumultuous 
applause, my curiosity could take no more. 
It took about five minutes of pushing and 
shoving to make it through the 15 deep 
crowd to get close enough to see what was 
going on. There were two people sitting in 
aircraft type chairs holding what appeared to 
be small control consoles. They and the 
entire crowd were intently watching a 21 


Figure 1; Raster Scan versus Analog Vector Graphics. For а given grid size and a figure covering a particular area (such as 4 by 4 
or 8 by 8), the analog vector graphics method will give a better picture, where better is defined as a closer approximation of the 
figure desired. 


a. Drawing a circle with a slant line through it is 
unrecognizable on a 4 by 4 grid of raster dots, but quite 
believable when drawn on a 4 by 4 vector graphics grid. A 
line drawing of the “ideal” circle with slash overlays the 
approximations for reference. 


—— =IDEAL FIGURE 


b. Drawing a circle with 
a slant line through it is a 
closer approximation on 
an 8 by 8 grid of raster 
splotches, but the 8 by 8 
equivalent vector line 
drawing has a still closer 
approximation to the 
desired circle and line. A 
line drawing of the “ideal” 
circle with slash overlays 
the approximations for 
reference. 


—— = IDEAL FIGURE 
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c. When it comes to detailed graphics, the 
vector method is a real winner. Here is a 
cartoon figure rendered on a 16 by 16 grid 
in both vector and raster scan dot matrix 
form. The contrast in effective resolution of 
the two methods is enhanced by the juxta- 
position of the two versions in this overlay. 
Note that within the same coordinate grid, 
the vector graphic version is able to represent 
some limited alphanumerics, impossible to 


even attempt in the raster graphics version. DDE = 


і 
T 
п 


—— VECTOR GRAPHICS FIGURE 
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inch black and white TV screen upon which 
there was a scene depicting a star-studded 
space and two rocket ships. It became 
obvious very soon that they were playing 
"Space War," and the only rules were to 
shoot the other guy out of the sky (Do Unto 
Others...), while not getting wiped out 
yourself. There were certain limitations on 
fuel and armaments which made the game all 
the more interesting. 

| stood and watched this for three hours 
until | jockeyed myself into position to grab 
a control console from an exiting player. All 
right, you guys, let's play Space War! | 
played for what seemed to be an instant on 
the time continuum; but it was obviously 
too long in the crowd's opinion because, 
when some little kid started pulling one of 
my socks down and І let go of the control 
console to retaliate, | was six deep in the 
crowd again before | regained control. | did 
eventually get another try, but | was already 


RASTER SCAN GRAPHICS — SUMMARY OF 
ADVANTAGES AND DISADVANTAGES 


Advantages 


. No software refresh — computer can load a 
display once and continue other duties. 

. Fully digital — does not require any analog 
conversion or associated "'tweeking" of 
components. 

. Hequires no special display tube — uses tele- 
vision monitor. 

. Can be color — by using added storage, 
color or gray tones can be assigned to each 
element or group of elements. 

. No limit to total display quantity — since 
storage is provided for all points it is 
irrelevant whether they are shaded or not 
and does not affect display refresh time. 

. Inexpensive — in limited forms, raster scan 
uses inexpensive televisions or monitors. 


Disadvantages 


1. Not a pure line display — display is a con- 
nection of shaded squares and not line 
segments. 

. Must provide memory for total dis- 
play — for a 256 by 256 point display, 8 K 
bytes of memory must be provided even if 
only one element is being displayed. 

. Must use either an external memory or 
direct memory access — the composite video 
signal necessary for raster scan requires a 
data output rate beyond the capability of 
the processor itself. Special controllers must 
be provided to either access standard pro- 
gram memory directly by DMA or scan an 
external display buffer which can be peri- 
odically changed by the processor to cor- 
respond to changing displays. 

. May require fast memory access — in DMA 
using cycle stealing, memories having access 
speeds of 250 ns or better may be required. 
(With a dedicated buffer memory or multi- 
port memories, 2 us access is typically 
required.) 


80 


a confirmed “Space War" freak. | was 
determined to have one of my very own that 
| could play until my heart was content. 

The realization of this dream was, of 
course, to be postponed until just recently. 
It is now possible for the computer experi- 
menter to put together a system with capa- 
bilities rivaling computers costing many 
times more. The LSI microprocessors which 
have become increasingly available at modest 
prices have started a boom in the home 
computer field with price wars inevitable. 
The major reason that these small computers 
have realized so much computer power is 
that designers have tailored their designs to 
utilize existing hardware which is available 
readily. Consider mass storage, for example. 
Talk to ІВМ or any "traditional" computer 
company about mass storage and your dis- 
cussion will lead to a $30 K tape drive and 
controller with reams of wonderful toler- 
ances and grandiose specifications. This will 
provide an unparalleled mass storage capabil- 
ity, but most people would be upset just 
considering the electric bill. The alternative 
was, and is, to incorporate the principles 
that make the “biggies” so good, but make it 
cheap enough so the average person would 
not go into cardiac arrest over the price. 
American ingenuity had the answer. Develop 
a sophisticated, yet simple modem on a 
cheap printed circuit board which allows the 
owner to use his kid's cassette tape recorder 
to store data. Thus came the invention of 
the $100 mass storage system. 


There is а moral to all this. The initial 
success of the home computer system can, in 
large part, be directly attributed to inexpen- 
sive peripherals which utilize readily avail- 
able surplus equipment or home entertain- 
ment devices such as tape recorders and 
televisions. The television typewriter, other- 
wise called an alphanumeric CRT display, is 
only $150 because it uses an already existing 
television. 


Raster Scan Graphics 


There is an unfortunate lack of sophisti- 
cated peripheral devices beyond these few, 
and applications using these are limited. The 
Space War game previously mentioned re- 
quires a graphics CRT terminal upon which 
the players and playing field may be dis- 
played. The home raster scan television, such 
as that borrowed for an alphanumeric CRT, 
can be used; but the display is overly 
complicated and will appear as a connection 
of blocks rather than pure line segments. 
There are many raster scan graphics systems 
now on the market but all exhibit this 
“block” phenomenon, which in the simplest 
terms is a function of the resolution. A low 


resolution display will have a limited number 
of large blocks and a high resolution display 
will have a great quantity of small blocks. 
Making various blocks light or dark 15 what 
constitutes a picture. Figure 1 illustrates a 
circle drawn on a screen with 16 elements 
(4 by 4) versus one which has 64 (8 by 8) 
elements. The lower the resolution of the 
display medium, the less recognizable the 
display. For true graphics detail necessary in 
applications such as game boards and pla- 
yers, high resolution on the order of 
256 by 256 is required. This leads to another 
interesting problem: display storage and 
addressing. 

Raster scan graphics is nothing more than 
a sequential video display of mass memory. 
The “‘mass” in mass memory is a function of 
the resolution. If the display has a total of 
64 elements, 8 bytes (8 bits each) of 
memory are required for storage. If the 
display were 64 by 64, there would be 4096 
picture elements requiring 512 bytes of 
memory. It is important to remember that 
the entire 512 bytes is necessary regardless 
of the picture being displayed. Within this 
display storage, each bit has to have a unique 
X and Y address: For a 64 bit display X and 
Y could each be defined with 3 bits; for a 
4096 bit display 6 bit X and Y addresses 
are necessary. 


Most home computers are 8 bit machines 
and obviously work most efficiently with 
8 bit manipulations. Taking full advantage of 
this and defining 8 bit X and Y display 
addresses results in a very respectable 256 X 
by 256 Y display grid containing 65,536 
elements. This corresponds to 8K 8 bit 
bytes of memory. [See the article by 
Thomas R Buschbach on page 32 of this 
issue for an example of such a design.] 

Going from the memory to the screen is 
another problem and requires a special con- 
troller to translate the memory into video 
information. Horizontal scanning rate of a 
television is 15.75 kHz which is 63 us. If a 
horizontal line is to be divided up into 256 
elements, each must be scanned and output 
to the TV one every 250 ns. Even if address- 
ing and output were handled 8 bits at a time, 
the rate will still be one byte every 2 us. 
Very few microprocessors are capable of 
doing this. There are two methods of 
acquiring this data. First is to have a 
dedicated 8 K memory in the graphics con- 
troller which is synchronously scanned by 
the video output generator and asynchro- 
nously updated via the output ports of the 
computer. This method, though easiest from 
a design perspective, is the most costly due 
to the extensive memory used only for the 
graphics controller. 


ANALOG GRAPHICS — ADVANTAGES 
AND DISADVANTAGES 


Advantages 


1. Does not require extensive memory — total 
memory required is whatever is necessary to 
store all the beginning and end points of the 
line segments to be displayed. Blank areas 
do not require storage. 

. High resolution and low cost — a simple 
controller is designed around low cost DACs 
and an analog display does not exhibit 
"staircase effect'' on diagonal lines. 

. Uses available test instrument as display — 
an inexpensive oscilloscope or other X,Y 
display may be used as a display medium. 

. Does not require fast memory — any storage 
medium having a byte access time of approx- 
imately 100 us is adequate. Can use shift 
registers, delay lines, etc. 

. Resource conservation — gives the author 
some reason to use his 8008 system since he 
bought an 8080А. 


Disadvantages 


1. Software refresh — the processor must 
periodically rewrite data on the screen to 
keep it from fading. Refresh rate is a 
function of processor speed and the total 
number of line segments in the display. 

. Uses analog circuitry — all analog circuitry is 
subject to drift and to temperature and 
other external influences. These variations 
can be minimized through proper design and 
construction. 


The second method which is used most 
often in the graphics industry is called direct 
memory acces, 8K of memory is still 
required for the 64 K element display, but it 
is attached to the computer. lt is directly 
addressable at all times and not externally 
located in the graphics controller, so that 
when the graphics option is not in use, this 
8K is utilized as any other portion of 
memory. When using the graphics operation 
this 8 K will contain the bit pattern display 
of the screen and be shared between the 
processor and the graphics controller. Direct 
memory access means just what it says. The 
DMA controller directly addresses and reads 
memory when the processor is not doing so. 
In most microprocessors this sharing can be 
done either by suspending the processor 
operation with hardware DMA request and 
hold logic or by accessing memory on clock 
cycles when the processor is doing some- 
thing else. Suspending processor operation is 
easiest from both a design and component 
standpoint but least effective when simul- 
taneously running large programs. In a raster 
scan display, the processor would be shut 
down and memory read out 30 times a 
second to correspond to the non-interlaced 
update of standard television. The only time 
the processor would be allowed to run 
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would be during vertical retrace which is 
approximately 4 ms out of every 33 ms. 
Therefore about 400 instructions (in an 
8080A) could be run every frame. This is 
quite acceptable for most non-iterative pro- 
grams, but it would kill response in inter- 
active Space War type games which do a fair 
amount of number crunching. Modifications 
to this method can extend processor time 
somewhat but they become involved. DMA 
utilizing "stolen" clock cycles or added wait 
cycles is the most effective technique since it 
does not significantly reduce processor 
calculation speed. Not all microprocessors 
are capable of doing this, though; and many 
more design constraints are involved. An- 
other method which avoids waiting by the 
processor is to use amultiport memory with 
priority allotted to the processor. This leads 
to some picture breakup during updates but 
allows the processor to run at full speed. 

Some such form of direct memory access 
is the much preferred system for high 
resolution raster scan graphics but can be 
very expensive when considering the quan- 
tity of memory necessary for display 
storage. 


Analog Graphics 


For those of you that haven't ordered a 
raster scan graphics controller after reading 
the previous dissertation, | would like to 
present the other side of the story: analog 
graphics. Usually the thought of anything 
analog associated with a digital computer is 
abhorrent to the purist, Remember, before 
there was digital there was analog; and even 
though it's hidden, analog's still there. The 
success of digital systems is based upon their 
ability to evaluate an action or output a 
value repeatably with no deviation from 
previous occasions, given constant input 
data. This is inherent in the machine struc- 
ture, since it can only exist in either of two 
discrete states: 1 or 0, on or off, etc. Analog 
on the other hand can be influenced by 
external conditions such as temperature and 
power supply levels, etc, and is repeatable 
only within a more or less closely defined 
tolerance band. Industry has been tightening 
this tolerance band in recent years to such a 
point that analog circuitry becomes too 
expensive and digital methods are imple- 
mented. Too often, though, the "band 
wagon syndrome" prevails. Many applica- 
tions which can be adequately accomplished 
using analog techniques have been converted 
to digital. In most cases this unnecessary 
conversion to digital can be very costly and 
requires expensive support equipment. The 
tolerance tightening which makes an in- 
dustrial manufacturer use only digital does 
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not exist for the home computer enthusiast. 
Many applications can be more cheaply done 
with analog. A prime example of this is 
graphics. 

Analog graphics is a method which con- 
verts digital data stored in memory to 
voltage levels proportional to that value. 
Two of these digital to analog converters 
would be incorporated to provide two simul- 
taneous outputs which represent physical X 
and Y coordinate locations on a display 
screen. The display's X and Y full scale 
deflection would be directly proportional to 
some analog constant times the digital value 
in the memory location being accessed. The 
display medium is an oscilloscope or similar 
two dimensional proportionally deflected 
display. 

As was the case with raster scan graphics, 
analog graphics has both its advantages and 
disadvantages. The most pronounced advan- 
tage is the display method itself. Two bytes 
of memory converted to analog X and Y 
positions define the starting point of a line 
segment and two more set the analog values 
of the end point of that segment. When 
triggered by the controller a line will be 
drawn between these points. Four bytes 
define the entire line regardless of the length 
(within the limits of the screen dimensions 
of course). There is no need to define and 
store points along the line, only the begin- 
ning and end point. When using an 8 bit X 
and Y addressing system there are 64 K total 
locations between which line segments may 
be drawn. The path between any two points 
is direct line and need not coincide with an 
addressable point location. This results in an 
extremely high resolution display even 
though it is only 256 by 256. [his means 
that in a diagonal line there is absolutely no 
"staircase effect" inherent in a raster scan 
display. This ànd relative low cost are the 
chief advantages. 


The major disadvantage of this system is 
that it requires software refresh. When begin- 
ning and end points are sent to the con- 
troller a line is drawn — once! It will be seen 
briefly on the screen and quickly fade unless 
it is refreshed. The computer must do 
whatever it has to do and get back to the 
graphics driver program and write the same 
line segment again before it fades. This time 
between refreshes is a function of phosphor 
persistence, a characteristic of the CRT 
being used. 25 to 40 ms is usually the 
maximum and if exceeded will result in 
display flicker. (Storage tubes exist with 
longer time constants, but at much higher 
expense.) The number of lines which can be 
written and refreshed is a function of proces- 
sor speed. The faster the processor, the 


sooner it will be able to write a screen, do its 
own thing somewhere else, and return to 
start writing the screen again. All the dis- 
plays in this article were driven by a slow 
8008 processor (not an 8008-1) system and 
about 120 lines could be drawn before any 
flicker was perceptible. This was using a 
worst case programming technique (the one 
Vm best at) which PI explain later. Faster 
processors would of course increase the 
number of lines capable of being displayed, 
but would have to have some delay loops in 
the software so as not to overdrive the 
graphics controller. The digital to analog 
conversion does take a little time. 


An Analog Graphics Controller 


The circuit for such an analog graphics 
controller is illustrated in figure 2. This 
circuit is based upon a design originally 
proposed by Hal Chamberlin in the first 
three issues of The Computer Hobbyist. 
Modifications and additions have been incor- 
porated to allow more ease in calibration. 
The circuit consists of three major sections: 
digital input latches, digital to analog con- 
verters, and vector generators. 

Since the graphics controller is software 
driven, possibly the software side is the 
easiest starting point. Positioning and draw- 
ing a line on the display is accomplished 
through four output commands from the 
processor. These commands are not some 
new processor instructions but rather de- 
coded output strobes which transfer 8 bit 
position data from the accumulator to the 
controller's input latches ІСІ to IC3. These 
four strobe commands are appropriately 
referred to as X-MOVE, Y-MOVE, X- 
STORE, Y-DRAW. In actuality, X-MOVE 
and Y-MOVE are the two bytes of data 
which define the starting location of a line 
segment while X-STORE and Y-DRAW is 
the end point of that line segment. There are 
four separate outputs necessary because we 
assume an 8 bit machine and 16 bits of XY 
positional data is needed to define a point 
on the screen. Obviously, in a 16 bit 
machine, this process could be reduced to 
two output instructions. Extra decoding is 
often not necessary. Many microprocessor 
systems like the Scelbi series provide extra 
decoding logic on the back plane wiring 
while not mentioning it. The usual clue is to 
check the ІО decoder board in your system 
and look for an appropriate decoder chip 
such as a 7442 or 74154. Often only a 
couple of output strobes are utilized on the 
chip. In the case with the 7442 used in the 
Scelbi, the extra strobes allow quick unag- 
gravated hookup to the four necessary for 
graphics. 


ІС4 and IC5 are 8 bit digital to analog 
converters. Their function is to convert the 8 
bit position data into a current which is 
proportional to that value. IC6 and IC12 are 
current to voltage converters. The Motorola 
MC 1408-L8 consists of a reference current 
amplifier, ап R-2R ladder, and eight high 
speed current switches. A resistor between a 
reference voltage and pin 14 is set to 
produce a reference current of approxi- 
mately 2 mA. The R-2R ladder divides the 
reference amplifier current into binary 
weighted components which are fed to the 
switches. The output current from pin 4 will 
be proportional to the binary input to the 
converter. For example, if the binary input 
were equivalent to 128 decimal, then the 
output current would be (128/256) * 
2.0 mA which equals 1.0 mA. The current 
to voltage converter is set to produce —2.5 V 
for a 00 000 000 binary input and +2.5 V 
for 11 111 111. Exact calibration procedure 
will be given later. 


The heart of an analog graphics con- 
troller is the vector generator. This circuit 
does the actual drawing of the line on the 
display. Merely setting a starting location 
and jumping to an end point will not work. 
The beam's transition between the points 
would be so fast as to leave only a very weak 
trace if any at all. A vector generator 
provides a consistent drawing time of approx- 
imately 100 us, allowing for a very bright 
trace. 

Actually drawing a line segment is a 
simple series of events. First, the processor 
outputs sequentially the X and Y starting 
position coordinates with the X-MOVE and 
Y-MOVE commands. These values are stored 
in IC3 and ICT, respectively, and cause the 
digital to analog converters IC5 and IC4 
to follow suit. Within 3 us, IC6 and IC12 have 
settled out to a voltage representative of 
these coordinates. 1C10 and IC11 are analog 
switches which route the raw X and Y 
voltages through the vector generator. These 
CMOS switches, equivalent to SPST, are in 
the off state when their control terminals are 
at a potential equal to Урр (—7.5 V) and on 
when it is at Vgs (+7.5 V). IC19 is a voltage 
translator which converts TTL switching 
levels to those necessary for this CMOS 
device. An alternate circuit to replace the 
DM8800 is also provided. 

In the quiescent state switches SW1 and 
SW3 are on and switch SW2 is off, as con- 
trolled by signals T1 and T2. This allows 
the output of the vector generator to be 
equal to the coordinate position of the 
beginning of the line segment. The trace is 
blanked at this time so the dot does not 
appear on the screen. Next, X-STORE then 
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SECTION 


Figure 2: Schematic Diagram of a Vector Graphics Controller. This circuit will produce signals with a range of —2.5 V to +2.5 V 
for use in driving a standard XY oscilloscope with bandwidth greater than 100 kHz. The power supply wiring of digital 
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Е NOTES: 
V 


1. Resistors are 1/4 W, * 596 unless noted 
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integrated circuits used іп this circuit is summarized in table 1. (Analog integrated circuits have their power wiring indicated in 
the diagram. These circuits are listed in table 1 but have no power connections indicated.) 
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Static 
1. 


Table 7: Integrated Circuit List. This table 
gives each integrated circuit required in 
figure 2, along with its device type and, in 
the case of the CMOS and TTL digital 
circuits, power wiring pins. 


TTL power CMOS power 
+5 V GND -75У +75V 

ІСІ 74100 24 7 - - 
ІС2 74100 24 7 - - 
ІСЗ 74100 24 7 - - 
IC4* МС1408-:8 13 2 - - 
IC5* MC1408-L8 13 2 - - 
ІС6% LM301A — - - - 
ІС?" LM301A - - - - 
IC8* LM301A - - - - 
ІС9% LM301A - - - - 
IC10 CD4016 - - 7 14 
{C11 CD4016 — - 7 14 
1С12* LM301A - - - - 
ІС13% LM301A 

ІС14% LM301A - - - - 
ІС15% LM301A - - - - 
IC16 74123 16 8 - - 
ІСІ? 174121 14 7 - - 
!С18 7410 14 7 - - 
IC19 DM8800 10 3 7 4 
IC20 7404 14 7 - 
ІС21 7437 14 7 - - 


*Analog circuit connections аге indicated іп 


figure 2. 


NOTES ON CALIBRATING THIS 
GRAPHICS CONTROLLER 


Calibration 


With all components except integrated cir- 
cuits inserted and mounted, and presuming 
that you have no direct shorts, attach the 
controller to + and —15 V and +5 V and 
turn it on. 


. Using a meter, check to see that the right 


supply voltages are on the appropriate inte- 
grated circuit pins. Check to see that VRef 
is approximately 5 to 5.1 V and that the + 
and —7.5 V Мор and Vsgs supplies are 
correct. If substituting parts, don't use а 
zener any higher than 7.5 V since it could 
damage the CD4016s. 


. Insert only ІСІ through IC3. Using either 


hard wire jumpers, switches or a computer 
program to drive the data bus lines BO 
through B7, take note that when the bus 
inputs are ali high, pins 5 through 12 of 
1C14 and 1C15 are also high. Grounding all 
data bus inputs should result in low levels 
on these pins. It is a good idea to go down 
the bus one pin at a time to make very sure 
that all input lines end at the correct DAC 
pins, otherwise the digital to analog conver- 
sion will be incorrect. 


. Turn power off. Insert the DAC 1С4 and op 


amp 1C6. Attach a meter to read the voltage 
at pin 6 on IC6. Set the bus input switches 
or programmed data value to provide a 
binary code of 10000000 (200 octal). 
Turn power on and adjust the zero pot (R3) 
on IC6 until the output at pin 6 reads zero 
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Y-DRAW are executed. X-STORE loads the 
X coordinate of the endpoint into 1С12 
where it stays for the moment and does 
nothing. When a Y-DRAW is executed, the 
whole unit comes to life. Y-DRAW loads the 
Y endpoint coordinate into ІСІ and trans- 
fers the contents of ІС2, the X coordinate, 
into 1СЗ, and both X and Y converters start 
to settle toward the endpoint value. Simul- 
taneously with this action, switches SW1 and 
SW3 are turned off by T1, keeping the beam 
position where it was. After about 10 us, 
switch SW2 is turned on by T2, the beam is 
unblanked and the output of the vector 
generator starts moving toward the endpoint 
values. This transition or drawing time is 
approximately 100 us and is a function of 
the endpoint adjustment on IC17. It should 
be noted that the movement from the old 
value to the new value is an exponential 
function adjusted through the slope con- 
trols, but the lines between points will be 
straight since both X and Y are charging in a 
similar manner, though the velocity (hence 
brightness) of the beam does vary a bit from 
beginning to end. At the conclusion of the 
draw cycle, the beam is again blanked and 
the controller is ready to draw the next line. 
(The beam will be positioned wherever it 


volts. Change the input code to 11 111 111 
(377 octal) and adjust the span pot (R6) 
until the output is +2,50 V. Setting an input 
of 00000000 (0 octal) should result in 
—2.50 V out. The same procedure is used to 
calibrate ІС5 and 1С12. (Zero with R14, 
span adjust is R17.) 

5. Turn off power. Insert ІС16 through 1С21. 
Temporarily, around pins 1, 3 and 5 of 
ІС20. Turn power on. Using either a push- 
button or cliplead intermittently ground 
1C20 pin 7 simulating a Y-DRAW strobe. A 
scope should be used to determine that 
IC16 pulses for about 10 4s and then 
triggers 1C17 which lasts for about 100 us. 
Control lines T1 and T2 should cycle 
between +7.5 V and —7.5 V corresponding 
to their TTL inputs. 

6. Turn off power. Insert all the rest of the 
integrated circuits (be careful of the CMOS) 
and temporarily remove ІС21. Reapply 
power and use the method in step 4, but 
take note that pins 6 on IC9 and 1С15 are 
equivalent to IC6 and IC12 respectively. 
Turn off power, reinsert ІС21. This con- 
cludes static checkout. 


Dynamic Calibration 


1. Unless you have super fast fingers on 
mechanical switches, a computer is neces- 
sary for dynamic checkout (while it is 
optional in static checkout). It is necessary 
to write a short program which outputs to 
the controller the full scale coordinates of а 
square with two diagonals (see figure 3). 


was left from the last line segment, so it is 
possible to reduce software overhead con- 
siderably on continuous line graphs by just 
issuing a series of new endpoints.) 

Maximum drawing rate can easily be 
determined for those who wish to use a 
faster processor. Each voltage converter re- 
quires about 3 to 5 us to settle out and a 
draw cycle takes 110 us. This means that 
5 us at least must be allowed between input 
of the beginning and endpoints and 110 us 
must lapse before starting the next line 
segment. With an 8008 such as [ used, there 
is little possibility of driving the controller 
too fast, but with an 8080A system a delay 
loop may be necessary between segments. 
The next step is to do some cartooning with 
software. 

Obviously before we can get too carried 
away discussing graphics software you must 
get your controller calibrated and working. 
The procedure outlined in "Notes on 
Calibrating This Graphics Controller" should 
result in the best chance for success. 


Now How Do I Use It? 


Now that the hardware of vector graphics 
has been conquered, you should be ready 


This square is all that is necessary to check 
out the remainder of the controller inter- 
face. (The X, Y and blanking outputs of the 
graphics controller have to be connected to 
an appropriate display. Any XY oscilloscope 
with a 100 kHz frequency response and an 
external horizontal input capability will 
suffice. The controller has to be connected 
to the output data bus and four decoded 
strobe lines.) The software which draws the 
calibration square is quite simple and con- 
sists entirely of outputting a list of co- 
ordinates stored in memory. The program of 
listing 1 was written for an 8008 system but 
is easily adapted to others. 

2. If upon first turning on the display you 
obtain a perfect square with the diagonal 
meeting in the corners, go have a martini 
and relax, you're done (see figure 1c). It is 
more likely that the displays will only 
vaguely look like a sqüare. lf the line 
segments are too long or are too short and 
don't meet in the corners, adjust the end 
match adjustment, R24, on (C17, until 
perimeter segments (disregard the diagonals 
at this point) meet in the corners. 

3. Next, fiddle with the slope adjustment pots 
(R10 and R21) until the diagonals meet in 
the corners. Any problems in accomplishing 
any of this is probably a result of the 
following: Frequency response of the op 
amps is too low (don't use anything slower 
than a 301A}; the RC time constant of the 
slope adjustment is inadequate; your 
CD4016 crapped out; or your program is 
outputting incorrect coordinates. 


to write some simple display routines. Any- 
one owning a home computer system is 
always at a loss to justify it to friends and 
family who continually ask what purpose it 
serves. By using a little psychology and 
realizing that these people identify most 
often with Mom's apple pie, McDonald's 
and Star Trek, a little ingenuity can go a 
long way. Graphics goes a long way in 
impressing nonbelievers, especially when the 
computer is generating a picture of the USS 
Enterprise, shown in photo 1. 

Drawing the Enterprise entails a program 
(see listing 2) which is very similar to that 
used for calibration (listing 1) except that 
the point list is longer so the program is 
written to accept variable length lists. There 
are many methods to program graphics. The 
easiest from the software point of view, but 
the worst for drawing speed and total 
number of lines, is to treat each line as an 
entity in itself. Four bytes would define the 
line segment as in listing 1’s data table. This 
is required wherever it was placed on the 
screen, disregarding those displays which 
appear continuous as would be the case of a 
square or a triangle. As a specific example, 
12 bytes are required to store the coordi- 
nates of a triangle when the three sides are 
treated as three line segments. Only 8 are 
required if a continuous drawing technique 
is incorporated. The problems arise when a 
display is made up of both disjointed and 
continuous lines. The program can be 
written to output one list of continuous 


(000,377) VECTOR NO.3 
VECTOR NO.6 
VECTOR 
NO.4 
(000,000) VECTOR NO.I 
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Figure 3: Vector Graphics 
Test Pattern. The vector 
graphics generator is 
calibrated | dynamically 
using a program like the 
one in listing 1, to produce 
a 6 segment square with 
diagonals at the extremes 
of the display grid of 256 
by 256 points. In this fig- 
ure, the vectors are identi- 
fied, and octal coordinates 
of the endpoints are 
shown in parentheses. 


(577,577) 


VECTOR 
NO.2 


(377,000) 


lines and then jump to a list of separate line 
segments. This is the obvious method to 
accomplish graphics using a slow computer 
USS ENTERPRISE and lengthy display lists. Some problems 
arise when trying to translate such a picture 
from one point to another. A way of dealing 
with the problem of translation of picture 
elements from one location to another was 
suggested by Richard Lerseth in his article, 
“A Plot Is Incomplete Without Characters” 
on page 64 of July’s BYTE. His technique is 
to use picture elements specified as a series 
of relative coordinates, to which the X and 
Y position coordinates are added at the time 
the image is displayed. (His method also 
involves economizing storage by using linked 
chains, but that is a slightly different issue.) 
When using a fast processor such as an 
8080A or Z-80, the time required for a 
routine to do simple 8 bit additions for X 
and Y coordinates should be about the same 
(order of magnitude, 100 us) as the vector 
drawing time of the circuit in figure 2. For 
those of us who have slower first generation 
processors, use of separate line segment lists 
with absolute coordinates calculated in ad- 
vance may be a requirement if the screen is 
to show a complicated picture without 


Photo 1: The author's Sanders 708, a surplus vector graphics display, shown 


portraying the Star Ship Enterprise using data of table 2 and figure 4. The 
lettering is not included in table 2. 


Listing 1: An 8008 Program to Generate the Calibration Pattern. The listing 
uses original Intel 8008 mnemonics, the data table at the end of the listing 
contains two bytes of starting coordinate followed by two bytes of ending 
coordinate for each point in the pattern. 


Split 

Octal 

Addr Octal Code Label Op Operand Commentary 
001/000 056 001 START LHI H(TABLE) Page address, data table; 
001/002 066 040 LLI L(TABLE) Byte address, data table; 
001/004 307 XFERLOOP LAM A := XMOVE value; 
001/005 143 OUT ХМОУЕ Perform XMOVE output; 
001/006 060 INL Point to YMOVE value; 
001/007 307 LAM A : 2 YMOVE value; 
001/010 147 QUT YMOVE Perform YMOVE output; 
001/011 060 INL Point to XTORE value; 
001/012 307 LAM А := XSTORE value; 
001/013 145 OUT  XSTORE Perform XSTORE output; 
001/014 060 INL Point to YDRAW value; 
001/015 307 LAM A := YDRAW value; 
001/016 151 OUT YDRAW Perform Y DRAW output; 
001/017 060 INL Point to next YMOVE value; 
001/020 306 LAL A := L [check end address 

low order] ; 
001/021 074 070 CPI L(TABLEND) ls end of table reached? 
001/023 110 004 001 JFZ XFERLOOP If not then continue loop; 
001/026 104 000 001 JMP START Restart pattern when done; 
С” octal coordinates -—— — — — —4 

Split С” start —_ С” епа ——À 

Octa 
Address Label XMOVE YMOVE XSTORE YDRAW Commentary 
001 040 TABLE 000 000 377 000 Vector #1; 
001 044 377 000 377 377 Vector #2; 
001 050 377 377 000 377 Vector #3; 
001 054 000 377 000 000 Vector #4; 
001 060 000 000 377 377 Vector #5; 
001 064 377 000 000 377 Vector #6; 
001 070 TABLEND ххх 
Notes: 


XMOVE, YMOVE, XSTORE and YDRAW are output port assignments of the author's system, 
corresponding to the strobe lines of figure 2. 


All constants in this listing are octal. 


H(TABLE) is high order 8 bit field of address of TABLE; L(TABLE) is low order 8 bit field of 
address of TABLE. The two high order bits of H(TABLE) are ignored. 


88 


flicker, However, a surprising number of 
lines can be displayed before flickering 
occurs when using the separate line tech- 
nique. 

To write a stationary display routine, it is 
necessary to determine the coordinate points 
of the picture’s vectors. Graph paper which 
has been ruled for 377 by 377 octal squares 
(or hexadecimal if that’s your preference) is 
not easily obtained, so be ready to count 
squares and label ordinary graph paper. 
Figure 4 illustrates the technique of creating 
a display table using graph paper. The 
illustration is drawn first, using a ruler or 
other straight edge to provide the lines. A 
pencil is a must at this stage, since erasure is 
a very real requirement when working out 
any sketch. Once the drawing has been 
finalized, octal coordinates are added to the 
basic graph paper pattern. In the case of the 
Enterprise, | wanted to fill the screen, so | 
scaled the coordinates to use most of the 
display area in the horizontal (X) direction, 
and used the same scaling in the vertical (Y) 
direction. Then, the vector list is created by 
going over the drawing line by line and 
determining the four coordinates required. 
The small numbers near the line segments in 
figure 4 identify the octal addresses of these 
line segments in the vector table, table 2. 
When the data for a picture is all encoded 
from the graph paper, it can be loaded into 
your computer’s memory. If your processor 
is an 8008, then the program of listing 2 can 
be loaded and executed; otherwise, you'll 
have to create an equivalent program for 


Photo 2: À scope trace of the X coordinate output of the circuit in figure 2 
during the display of a typical picture. The trace is 3 V full scale and is 
approximately 15 ms long. The transition time from one voltage to the next 
is fixed by the hardware at 100 us (approximately 1/150th of the horizontal 
width of this picture). 


your own processor. (The data of table 2 
remains the same regardless of the processor 
used.) 


What's Next? 


There is a fundamental problem with the 
home computer system or should | say the 
home computer experimenter. The systems 
keep getting bigger and more expensive. 


Continued on page 120 


Listing 2: An 8008 Program for Drawing Lengthy Pictures. This program is 
similar to the program in listing 1 with the addition of a generalized end of 
data test. In operation, it will be the sole program active in the 8008, 
continuously cycling through the vector table which starts at location 


001/050. 

Split 

Octal 

Addr Octal Code Label Op 
001/000 056 001 START LHI 
001/002 066 050 LLI 
001/004 307 LAM 
001/005 143 RFSHLOOP OUT 
001/006 060 INL 
001/007 307 LAM 
001/010 147 OUT 
001/011 060 INL 
001/012 307 LAM 
001/013 145 OUT 
001/014 060 INL 
001/015 307 LAM 
001/016 151 OUT 
001/017 060 INL 
001/020 110 024 001 JNZ 
001/023 050 INH 
001/024 307 NOINCH LAM 
001/025 074 377 CPI 
001/027 110 005 001 JNZ 
001/032 104 000 001 JMP 


Operand Commentary 
H(TABLE) Set up the memory pointer 
L(TABLE) to the beginning of table; 

A := XMOVE value; 
XMOVE Perform XMOVE output; 


Point to YMOVE value; 

А := YMOVE value; 
YMOVE Perform YMOVE output; 

Point to XSTORE value; 

А := XSTORE value; 
XSTORE Perform XSTORE output; 

Point to YDRAW value; 

A := YDRAW value; 


YDRAW Perform Y DRAW output; 
Point to next value; 
NOINCH If no overflow then test end of table; 


Else increment high order address; 
A :7 next value [may be XMOVE or 


END]; 
377 15 it END of data value? 
RFSHLOOP If not then continue inner loop; 
START Else restart the program; 
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YTE’S 


UGS 


Here lies documenta- 
tion of known bugs de- 
tected in previous editions 
of BYTE... 


Conversion Patch 


Regarding the September 1976 issue, the 
following points were phoned in by Bob Van 
Valzah, 1140 Hickory Trail, Downer’s Grove 
IL. 

On page 58, in listing 4b of James 
Brown’s article “How To Do A Number of 
Conversions,” a typographical error occurred 
at address 0021. The correct code and 
comment is: 


0021 6F MOV LA 


Bob also points out that zero suppression 
works “too well” with the decimal routine 
as designed by author Brown: It suppresses a 
zero value completely. Bob suggests the 
following patch replacing line 44 (and push- 
ing TENSTABL down in relative address 
space): 


MOV A,C get NONZERO flag; 

ORA A test and set flags; 

RZ original return if some digits 
printed; 

MVI дж output of an ASCII zero 

JMP PUT character and return if all 

blank so far; 
To use this patch, the reference to 


TENSTABL will have to be modified at 
location 0001,ш 


Patch of a Patch 
The suggested biorhythm program patch 


given on page 100 of your July issue 
contains an error. [his patch will, in fact, 
initiate all cycles in phase beginning at one's 
birthdate; but, if used as specified, errors 
occur in the incrementing of dates on the 
chart. By deleting lines 130 to 470, the loop 
which reads data into the vector T(l) is 
deleted. Data must be read into this vector 
in order for the chart dates to increment 
properly. | therefore suggest that the fol- 
lowing patch be added to the previous patch. 


122 FOR I = 1 TO 12 
124 READ T(I) 
126 NEXT (1) 


This may save problems for some of your 
readers. 


Gary Sleater 
302 E E! Caminito Dr 
Phoenix AZ 85020 m 


The Price Is Wrong 


According to IMS Associates, the price of 
the IMSAI floppy disk drive and interface 
controller mentioned on page 83-84 of 
BYTE's September 1976 issue is $1919 
assembled, $1719 unassembled; additional 
drives without a cabinet are $1095. The 
prices quoted in "What's New?" are incor- 
rect, m 
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Here Are Design Equations 


In Bruce Filgate’s article, “А Morse Code 
Station Data Handler," October 1976, we 
omitted the design equations for the NE567 
tone decoder which should have been 
printed in figure 6, page 70. To remedy the 
situation, here they are: 

Center Frequency: Е =1/(R1* C1) 
Band Width: BW = 1070 * SORT 
ол / (F * C2)) 

where: 

R1, C1 and C2 are as defined in figure 6, 
page 70 of October BYTE 

VI is the input voltage to the circuit 

F is the center frequency.m 


Refining the Plot 


Author Richard Lerseth reports that he 
received a letter from J} C Rucklidge, associ- 
ate professor of geology at the University of 
Toronto, Ontario CANADA. Prof Rucklidge 
used Richard's article (“А Plot is Incomplete 
Without Characters" in July 1976 BYTE) to 
program character outputs from his system. 
In so doing, he verified the accuracy of the 
printed tables, but found one minor error in 
equations 16 and 17 on page 70. These 
equations should read: 


X-XO*H*DHX-*(V—50)* DVX (16) 
Y=YO+H* DHY + (М – 5.0)* DVY (17)ҹ 


Caveat Programme 


Past history has shown that occasional 
typesetting or logic bugs occur in programs 
printed in BYTE. Readers who find such 
bugs are urged to claim a bit of fame in this 
column by sending us the evidence, and 
suggested patches. Two examples have been 
documented here this month.m 


A Bug Way Back 


Boyd S Miner, K4KEP, editor of Bits and 
Dits, the newsletter of the Carolina Com- 
puter and Radio Amateur Association, 
points out an error in the statement of 
amateur radio Teletype mark and space 
frequencies in the September 1975 issue of 
BYTE, page 32: 


Боп Lancaster puts out some real good 
articles but in “Serial Interface” in BYTE 
September 1975, page 32, he states that 
Ham radioteletype audio frequency shift 
keying (AFSK) 2125 is mark and 2925 is the 
space frequency. This "ain't so." The mark 
and space tones are multiples of 425 Hz. In 
fact they are the 5th and 7th harmonics. 
Therefore the mark is 2125 as stated but the 
space is 2975, not 2925. At the time these 
standards came into being the FCC required 
850 Hz shift, m 


A Note about Borrowing 
Routines from EDUCATOR 

The EDUCATOR program from the Digi- 
tal Group is an extremely effective way to 
learn what takes place within the processor 
when you are learning machine level pro- 
gramming. 

The EDUCATOR-8080 article in the July 
1976 BYTE [page 22] appears to contain at 
least two errors. | discovered these when 
attempting to use some of its text display 
routines. 

The article neglects to mention that the 


Complete System 


user defined subroutine CHRPR (character in a case! 

print) has to add 200 (octal) to the code in 

the accumulator to get a valid ASCII charac- KEYBOARD: 62 key upper & lower case * Greek; 
ter. 


TAPE INTERFACE: High speed, 1200 Baud! Cas- 


The subroutine CHEDT loops indefinitely j 
sette, programs included; 


on the first string of blanks. The HL register 


needs to be incremented after a string of ; 

blanks is output. | inserted an INX H (043 VIDEO INTERFACE: Е.А. Compatible; 

octal) between the present lines 000/310 MICROPROCESSOR: 6502 based system! 

and 000/313 appearing on page 26 of the 

July issue. MEMORY: 2K or 4K byte RAM minimum system 
Since the listings published are obviously monitor + 3K ROM sockets: 


not exactly those used in the Digital Group 

software, the readers should be advised that 

further debugging may be necessary. at o9 S.T.M. SYSTEMS INC. 
Dr Charles F Douds ©: Р.О. Вох 248 


$ 
281 Poplar St ъ Mont Vernon, М.Н. 03057 
Winnetka IL 60093 = 


IN WIRE-WRAPPING ӘК) HAS THE LINE... 


HOBBY-WRAP-30 


UNWRAP 


OK MACHINE & TOOL CORPORATION 


3458 CONNER STREET, BRONX, NEW YORK, N.Y. 10478 U.S.A. » PHONE (212) 994-8600 
TELEX: 125091 TELEX: 232395 


Clubs 


and Newsletters 


KIM-1 USER NOTES 


At the Midwest Regional Computer Con- 
vention held in Cleveland, a group of KIM-1 
users had the opportunity to meet with Rick 
Simpson of MOS. The group agreed that 
there was a need for KIM-1 owners every- 
where to be able to exchange ideas much 
like other user groups, and that a newsletter 
would act as a vehicle for that purpose. 

KIM-1 USER NOTES will be published 
every 5-8 weeks. Cost for subscriptions will 
be $5 for the next six issues (including first 
class postage). This rate is for US subscribers 
only. Make checks and money orders pay- 
able to: KIM-1 c/o Eric Rehnke. No cash 
please. Write: K/M-7 USER NOTES, c/o Eric 
Rehnke, Apt No. 207, 7656 Broadview Rd, 
Parma OH 44134. 


South Florida Computer Group — I/O 


In the August issue 1-4 it was announced 
that Dr Bruce Cameron will be the new 
editor of //O. Bruce is a research biochemist 
with Papanicolaou Cancer Research Insti- 
tute (PCRI or PAP). All inquiries, news 
items, articles, etc, should be sent to him at 
1155 NW 14th St, Miami FL 33136; or 
phone (305) 324-5572. 

The group has in the past sent com- 
plimentary issues to interested individuals, 
other clubs, and firms; but the club’s mailing 
list has grown to such a point that now it’s 
necessary to charge a fee of $2 per year for 
12 issues. This will not affect the exchange 
of newsletters with other clubs. 


Space Coast Microcomputer Club — Florida 


This club at present (August) consists of 
about a dozen individuals who are interested 
іп microprocessor-based computer systems. 
A few are employed at the John F Kennedy 
Space Center, while others are affiliated with 
Florida Institute of Technology and Florida 
Technological University. Many members 
also belong to the larger computer clubs 
such as the Southern California Computer 
Society and the Chesapeake Microcomputer 
Club. The purpose of this club is to further 
the usage of small computer systems through 
the mutual sharing of ideas and resources. 
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Ray O Lockwood would be interested in 
hearing from you. His address is: 1825 
Canal Ct, Merritt Island FL 32952, (305) 
452-2159. 


The New Orleans Hamfest and 
Computer Fest 


On October 30-31, the New Orleans 
Hamfest and Computer Fest will be held at 
Archbishop Rummel High School, 1901 
Severn Av, Metairie LA (a New Orleans 
suburb). This event is sponsored by the 
Jefferson Amateur Radio Club. 

The Louisiana Council of Amateur Radio 
Clubs, the Louisiana ARRL Convention, 
MAR and other amateur radio groups are 


scheduled to meet. Banquets, noncom- 
mercial and other exhibits are being 
arranged. Call-in frequencies will бе 


146.34-.94 and 3.95 MHz, 

Reservations and latest details may be 
obtained by writing to Dominick "Nick" 
Tusa, WASRMC, chairman, New Orleans 
Hamfest, POB 10111, Jefferson LA 70181. 


Byte Back — Ohio 


Compute, Evaluate, Trade is the name of 
a new club in Ohio. Meetings are held in 
members' homes on the first Saturday of the 
month. There are no dues, other than talent 
and a desire to exchange information. 
Business applications аге their special 
interest, Charles E Tyzzer Jr is the contact 
person, and he may be reached at 
(513) 268-6551 x587. The mailing address 
is: POB 104, Tipp City OH 45371. 


Southern New England Computer Society 


SNECS was formed at a meeting held in 
New Haven CT in July. Those present came 
from parts of Connecticut bordering on 
Rhode Island as well as Fairfield and the 
Hartford and New Haven areas. They repre- 
sented a broad range of hardware, software, 
business, educational, and hobby interest in 
computers. А newsletter is in the works, and 
it will be called YANKEE BITS. Anyone 
wishing more information on this group 
should write: SNECS, 267 Willow St, New 
Haven CT 06511. 


Ride the Data Bus — Michigan 


Data Bus is the official newsletter of the 
Southeastern Michigan Computer Organiza- 
tion. Subscription is only available to 
persons living more than 50 miles from 
Detroit, at $6 per year (unless you're a 
member). Data Bus is also available on a 
newsletter exchange basis to other clubs. 
The editor is Jon Tara (313) 833-2847. The 
address is SMCO, Data Bus, 665 W Hancock 
No. 304, Detroit MI 48201. 


Purdue Has PUNCH 


Michael A Troutman, PUNCH president, 
informed us of the official existence of the 
Purdue University Computer Hobbyist Club. 
Mike says they have a constitution and are 
fully recognized as a student organization. 
The club meets weekly in the digital lab of 
the Electrical Engineering Building. The 
group is also planning lectures by key 
speakers for every other month. Their 
resources (those of EE) include two 6800 
systems (Motorola and SWTPC), an 8080 
system, a KIM-1 system, several CRT ter- 
minals, Teletype, high speed paper tape 
reader and access to the EE Dept PDP-11/70 
timeshare system. 

Membership is limited to students, staff 
and faculty; however, for a small activities 
fee, anyone is welcome to attend meetings. 
All interested persons may write to PUNCH, 
Room 67, Electrical Engineering Building, 
Purdue University, West Lafayette IN 
47907. 


Charlotte, North Carolina 


A new club has been formed in the 
Charlotte NC area. Anyone interested in 
making contact with the Charlotte Micro- 
computer Society may call Dr Michael Allen 


MODEL CC-7 SPECIFICATIONS: 


A. Recording Mode: Tape saturation binary. 
This is not an FSK or Home type recorder. 
No voice capability. No Modem. (NRZ) 

. Two channels (1) Clock, (2) Data. OR, Two 
data channels providing four (4) tracks on 
the cassette. Can also be used for Bi-Phase, 
Manchester codes etc. 

. Inputs: Two (2). Will accept TTY, TTL or 
RS 232 digital. 

. Outputs: Two (2). Board changeable from 
RS 232 to TTY or TTL digital. 

. Runs at 2400 baud or less, Synchronous or 
Asynchronous, Runs at 4800 baud or less. 
Synchronous or Asynchronous. Runs at 
3.1" /sec. Speed regulation + .5% 


. Compatability: Will interface any computer 
or terminal with a serial !/О, (Altair, Sphere, 
M6800, РОРВ, LSI 11, IMSAI, etc. 

. Other Data: (110-220 V), (50-60 Hz); 3 
Watts total; UL listed 955D; three wire line 
cord; on/off switch; audio, meter and light 
operation monitors. Remote control of mo- 
tor optional. Four foot, seven conductor 
remoting cable provided. Uses high grade 
audio cassettes. 

. Warrantee: 90 days. All units tested at 300 
and 2400 baud before shipment. Test cas- 
sette with 8080 software program included. 
This cassette was recorded and played back 
during quality control. 


ALSO AVAILABLE: MODEL CC-7A with vari- 
able speed motor. Uses electronic speed control 
at 4" /ѕес, or less, Regulation + .2% 

Runs at 4800 baud Synchronous or Asynchro- 
nous without external circuitry. 

Recommended for quantity users who ex- 
change tapes. Comes with speed adjusting tape 
to set exact speed. 


SPECIALS 


+e +e ж ж 


DIGITAL DATA RECORDER $149.95 
FOR COMPUTER or TELETYPE USE 
Any baud rate up to 4800 


Uses the industry standard tape satura- 
tion method to beat all FSK systems ten to 
one, No modems or FSK decoders required. 
Loads 8K of memory in 17 seconds. This 
recorder, using high grade audio cassettes, 
enables you to back up your computer by 
loading and dumping programs and data fast 
as you go, thus enabling you to get by with 
less memory. Can be software controlled. 


Model CC7 . . .$149.95 
Model СС7А... $169.95 


NATIONAL multiplex 


CORPORATION 
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INTRODUCING THE 


COMPUTER 
WAREHOUSE 
STORE 


THE BIGGEST COMPUTER STORE 
IN THE WORLD! 


* ALL PURPOSE 12 inch 
VIDEO DISPLAY $150 
Long Persistence Green Phosphor 
100 PIN ALTAIR/IMSAI HEAVY-DUTY 
BOARD CONNECTORS - 55 
ONE DAY SHIPMENT ON IMSAI 8080, 
ADM-3,SwTPC 6800 & TERMINAL KITS 
USED TERMINALS, PRINTERS 
USED DEC PDP8 % 85 
USED DISK - TAPE DRIVES 
WRITE FOR OUR CATALOG 

THOUSANDS OF CABINETS, CASTERS, ELECTRONIC 


PARTS, MOTORS, POWER SUPPLIES, CONNECTORS, etc. 


DEPT. B, 584 COMMONWEALTH AVE. 
BOSTON, MASS. 02215 


NEW — 8080 I/O BOARD with ROM. 
Permanent Relief from "Bootstrap Chafing" 


This is our new ''turnkey'' board. Turn оп 
your Altair or Imsai and go (No Bootstrap- 
ping). Controls one terminal (CRT or TTY) 
and one or two cassettes with all programs 
in ROM. Enables you to turn on and just 
type in what you want done. Loads, Dumps, 
Examines, Modifies from the keyboard in 
Hex. Loads Octal. For the cassettes, it is a 
fully software controlled Load and Dump at 
the touch of a key. Even loads MITS Basic. 
Ends “Bootstrap Chafe" forever. Uses 512 
bytes of ROM, one UART for the terminal 
and one USART for the Cassettes, Our 
orders are backing up on this one. No. 2SIO 
(R) 


Kit form $140. — Fully assembled and 
tested $170.00 


Send Two Dollars for Cassette Operating 
and Maintenance Manual with Schematics 
and Software control data for 8080 and 
6800. Includes Manual on 
I/O board above. Postpaid 


Master Charge & BankAmericard accepted. 


On orders for Recorders and Kits please add 
$2.00 for Shipping & Handling. 
(N.J. Residents add 596 Sales Tax) 


3474 Rand Avenue, Box 288 
South Plainfield, New Jersey 07080 
(201) 561-3600 


at (704) 597-2303 days; and Allen Grayson 
at (704) 366-7879 nights. Allen Grayson is 
interested in down to earth applications for 
computers. An example is the one he cited: 
A friend wrote a program creating a robot 
lawn mower. Now his friend sits back with 
his favorite beverage under a nice shade tree 
and watches his ‘‘robot” do the work. 


Northern New Jersey 


The Northern New Jersey Amateur Com- 
puter Group opens its membership to any 
interested person for an annual fee of $5. 
Meetings will be held from 6:30 to 11:00 
PM the second Friday of each month at 
Becton Hall, Fairleigh Dickinson University, 
Rutherford Campus, Rutherford NJ. For 
further information, contact Murry Р 
Dwight, Dwight Instruments Company, 593 
New York Av, Lyndhurst NJ 07071. Phone: 
(201) 438-3334. 


TRACE — Ontario, Canada 


Toronto Region Association of Computer 
Enthusiasts has over 50 members in the 
greater Toronto, Hamilton, and Kitchener, 
Ontario areas. They meet once a month, 
usually on the first or second Fridays. For 
details concerning the club and newsletter, 
write: TRACE, Box 545, Streetsville, 
Ontario CANADA L5M 2С1. 


Waterloo — Ontario, Canada 


The Amateur Microprocessor Club of 
Kitchner-Waterloo, Ontario, has formed, 
with Charles Sooley acting as interim co- 
ordinator. The group has made some quan- 
tity purchases. For further information 
write: Amateur Microprocessor Club of 
Kitchener-Waterloo, Ontario, Canada, c/o 
Reading Room, Electrical Engineering, 
University of Waterloo, Waterloo, Ontario 
CANADA N2L 3G1. 


Auckland, New Zealand 


Info File of Mt Roskill has formed a 
group of N2 users and is asking help in 
getting off the ground. They need schema- 
tics, PC board layouts, and software. News- 
letters would be appreciated. Write: Info 
File, POB 27-206-B, Mt Roskill, Auckland 
NEW ZEALAND. 


Teen Hobbyist 


Jeffrey Rice, 16, of 303 Wilson St, Elkins 
WV 26241, would like to join or form a 
computer club in his area, if there is any 
interest. 

Enterprising Jeff, a would-be computer 
hacker, is working two paper routes and 
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holding a part time job assembling boards 
for a local microcomputer distributor. He is 
saving up to buy a 8800 or 6800 based 
system while attempting to educate himself 
in computer science. He writes that between 
the BASIC he's learning on the PDP 8/E 
system, the minimal configuration COSMAC 
computer he is building, and as much litera- 
ture as he can obtain, along with his ‘‘hands- 
оп” hardware experience with his job, he's 
doing OK. You can contact him at the above 
address, 


Ottawa — Ontario, Canada 


We have received word that a group 
calling itself the Ottawa Computer Club has 
formed. At the present time the only in- 
formation we have is that the meeting 
schedule is posted at Pettazzoli College 
Residence, located at Rideau and Chapel Av, 
Ottawa, monthly. They are looking for new 
members, and if you would like to play 
Sherlock Ohms, we suggest you investigate. 


Curriculum Developer Needs Inputs 


Robert F Tinker has founded Technical 
Education Research Center, located at 575 
Technology Sq, Cambridge MA, phone 
(617) 547-3890. He is interested in creating 
curricula in the emerging technologies of low 
cost electronics for student use. А news- 
letter, Hands On!, is proposed as a quarterly 
transmission line for practical laboratory 
oriented educational ideas with а bias 
toward the uses of electronics апа 
computers. 


Denver Amateur Computer Society 


DACS Newsletter, Volume 2/1, has mush- 
roomed. The July issue was expanded to 44 
pages. Some of the changes include longer 
features, new products, users’ reports, tips, 
and "Dear Nina," letters from wearied and/ 
or wearisome wives to the editor. The club is 
also holding a contest to come up with a 
name for the publication; the prize is a year's 
free membership. Entries, along with sub- 
scription orders ($9) should be sent to Jim 
Clark, DACS Newsletter, POB 6338, Denver 
CO 80206. 


RPI ACM Chapter (Capital District NY) 


Jerry Irving of RPI writes: The Rensselaer 
Polytechnic Institute student chapter of the 
ACM is forming a special interest group for 
people who are interested in minis and 
micros. We have had one meeting to see how 
much interest there would be and found a 
great deal of it. The group will be open to 
anyone, not just students. Those in the 


capital district area of New York should be 
just a short drive from RPI. There are many 
minicomputers on the RPI campus and a 
number of people at the first meeting work 
with these, rebuilding, programming or 
writing software for them. There are people 
in the area who were at the first meeting 
who are starting to build their own systems. 
This group is forming in order to supply a 
place for people to meet to compare their 
systems, exchange ideas, and give them the 
advantages of being in a nationally recog- 
nized organization. Once under way we will 
have regular meetings and try to have 
speakers and demonstrations as often as 
possible. 

We plan on having our organizational 
meeting to set up the foundation of the 
group in either August or September. 

Anyone interested in coming or joining 
should write to the RPI-ACM, Amos Eaton 
Hall, RPI, Troy NY 12180, or call either 
Jerry Irving (518) 756-6827 or Will Strang 
(518) 274-8361 for information and direc- 
tions. 


The Computerist — NECS 


The Computerist is an extension of the 
New England Computer Society. The club’s 
newsletter is prepared on a text editor, and 
is printed by reduced photo offset. In 


1702A MANUAL EPROM PROGRAMMER 


Features hex keypad, two 
digit hex address and two 
digit hex data display. Con- 
trols include load, clear, go! 
(step), key/copy, data in/ 
data out, and counter up/ 
down. Profile card includes 
high voltage pulse regulator, 
timing, 8 bit address and 8 | 
bit data drivers/receivers. Two 6%” x 9" stacked cards with 
spacers. Allows programming in 20 minutes — copying in 
5 minutes. Requires +5, —9, and +80 volts. 
ASSEMBLED $299.95 
$189.95 


The best of two worlds... use our 1702 EPROM programmer 


as a manual data/address entry programmer... or connect it 
to your processor. 

IMSAI/ALTAIR computer interface (requires 3 output ports, 
+1 input port) and software 

Briefcase unit with power supplies and interface connectors 
(assembled and tested only) $599.95 


ANNOUNCING 
Our NEW 16K Byte Pseudo-Static, IMSAI/ALTAIR compat- 
ible RAM. Single card slot. Uses less power than equivalent 
low power RAM. All memory chips socketed. Uses all prime, 
factory fresh ICs. High quality, two-sided, through-hole- 
plated circuit board. Crystal controlled, totally invisible 
refresh system requires NO software management. Just plug 
it in and use like STATIC memory. 
Complete kit $349.95 
Assembled, tested, and burned in 
ASSOCIATED ELECTRONICS 
12444 Lambert Circle » Garden Grove, CA 92641 
(714) 539-0735 


One Of The Nations Largest 
Full-Service Computer Stores. 


ТАЕ COMPUTER ROOM 


SMALL COMPUTER SYSTEMS е SOFTWARE е AMATEUR RADIO EQUIPMENT 


1455-А So. 1100 E. Salt Lake City, Utah 84105 Phone: 801-466-7911 


“WE TAKE THE 
ММА OUT OF THE MICRO ” 


we 


Over 1600 Square Feet Of Sales 
And Service Facilities. 


WHEN YOU WRITE FOR OUR CATALOG AND ENCLOSE $1 TO 
HELP DEFRAY THE COST OF HANDLING AND MAILING, 
HERE’S WHAT YOU GET: 


1. A CERTIFICATE GOOD FOR $2 ON YOUR NEXT 
PURCHASE. з. ec etur ie t erit oo e Er n OR dg patre 


2. THE COMPUTER ROOM Easy ТО UNDERSTAND 
CATALOG СОМЕВ!МС...................................... 


IMSAI 

THE DIGITAL GROUP 

POLYMORPHIC SYSTEMS 

SOUTHWEST TECHNICAL PRODUCTS CORPORATION 
TECHNICAL DESIGN LABS 

PROCESSOR TECHNOLOGY 

ETC. 


з. THE COMPUTER RUIT “Easy GUIDE” TO HELP YOU 
PICK THE RIGHT SYSTEM, PERIPHERALS, COMPONENTS, 
AND SOFTWAREFOR ...................................... 


THE BEGINNER 

THE ADVANCED 

THE EXPERT 

THE SMALL BUSINESS 


4. ACURRENTLISTING OF PRESENTLY AVAILABLE ....... 


SOFTWARE 
PUBLICATIONS 
PERIPHERALS 


5. INFORMATION ON REPAIR SERVICE, LOW COST 
CUSTOM PROGRAMMING AND OTHER SPECIAL SERVICES. 


AT THE COMPUTER ROOM YOUR WRITTEN QUESTIONS 
ARE HAPPILY RECEIVED AND PROMPTLY ANSWERED ...... 


WE ALSO STOCK A COMPLETE 
LINE OF AMATEUR RADIO EQUIPMENT 


ВАМКАМЕН!САҢР................................ MASTERCHARGE 


Volume 1/1 the goals are set forth: To serve 
all computerist and computer clubs in the 
New England region, report on club meet- 
ings, print a monthly calendar of regional 
events. [t will also provide up to date reports 
on new products, publications, local sup- 
pliers, mail order dealers, and the like. It will 
also include a classified section, and both 
commercial and individual advertisements. 
The Computerist is an independently pro- 
duced publication, which is the official 
newsletter of the New England Computer 
Society, and is supported in part by dues 
and subscription. Subscription rate is $6 per 
year, Robert Tripp is the contact man; his 
address is POB 3, South Chelmsford MA 
01824. 


Communication Co-operative for the Deaf 
and Hearing Impaired 


The Communication Co-operative is a 
nonprofit organization establishing a time 
sharing computer system in the Northwest. 
Its purpose is to provide data processing 
services in order to help support a communi- 
cations system for the deaf. This enables it 


to offer flexible computer services at reason- 
able rates and tailored to the needs of any 
business. Some of the services offered to 
businesses are inventory control, mailing 
lists, billing, and purchase orders. They also 
offer a 24 hour emergency service for the 
deaf, using Teletypewriter, and make avail- 
able national and local news stored in a file 
and accessed by the Teletypewriter. If you 
would like to learn more, write: Communi- 
cation Co-operative, POB 182, W Linn OR 
97068. 


Byte Out of Maple Address 


“Someone took a byte (or two) out of 
the address for MAPLE, and | don’t know 
whether all mail is arriving here,” writes 
John Sikorski, president of “Microprocessor 
APL Enthusiasts,” of the Clubs and Newslet- 
ters item on page 100 of September 1976 
BYTE. The full address is: 

MAPLE 

Box 574 NUMS 
303 E Chicago Av 
Chicago IL 60611 m 


Stamp Out Cybercrud 


COMPUTER 


BEUTE PETERBOROUGH, NH 03458 


Have you every been victimized by 
one of a myriad computer based inter- 
personal putdowns? In Ted Nelson’s 
book, Computer Lib/Dream Machines, 
you'll find an excellent essay on the 
nature of this “cybercrud.” 

Have you ever wondered where to go 
for a basic starting point in your quest 
for information about computer applica- 
tions and uses? Ted Nelson’s book, 
Computer Lib/Dream Machines, is the 
place for you to begin. 

Computer Lib/Dream Machines is for 
the layman — the person who is intelli- 
gent and inquisitive about computers. It 
is written and self published by a 
philosopher who is also a self confessed 
computer fan and an excellent teacher of 
basic concepts. (For those who have not 
yet heard, ivory towers are constructed 
out of real and substantial white bricks.) 
The most important aspect of this book 


r 
Piease add 50 cents for postage and handling, 


Send 


Name 
Address 


copies of Computer Lib/Dream Machines to: 


is its inspirational data content. The 
machines we’re all busy working on are 
deep personal expressions, and not the 
cold and inhuman monsters of the tradi- 
tional stereotype. The book defines 
many of the terms and explains many of 
the techniques which can be used in the 
personal computer systems we're all 
busy constructing and programming. It 
performs this service in a way which 
adds color and excitement to this newest 
of art forms, the computer application. 

Computer Lib/Dream Machines is 
must reading for the beginner, and is also 
a refreshing self examination for the old 
hand at programming and systems work. 

You can order your copy of Com- 
puter Lib/Dream Machines from BYTE's 
Books for $7. Send your order today to 
BYTE's Books, 70 Main St, Peter- 
borough NH 03458. Help stamp out 
cybercrud. 


Please allow six weeks for delivery. 


11 Check enclosed 
n Bill MC # 
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Exp. Date 
Exp. Date 


POLYPHONIC 
ALTAIR 38009 Y NTHESIZER 
& IMSAI BOARDS 


8US COMPATIBLE 


TWO BOARD SET 


Bd.] 585-320 
Generates any 4 notes 
іп а 4 octave range 
that can be shifted up 
оғ down for a total 
range of 9 octavesll 
(more boards-more 


notes) 
585-321 
Modifies tones from 
SRS-320 and controls 
all parameters of the 
sound at the command 
of the computer, 


PRICES 


51795.00 
21 72 оо?Оз%етЫед 


send for free info рас 
Stillman Research Systems 
5 a § РО. Box 14036 
Phoentx AZ 85063 
Dealer Inquiries Welcomed 
prices subject to change Wo notice 


COMPUTALKER 


SYNTHESIZER 


High Quality Voice Output 
Aitair/IMSAI/Polymorphic plug-in 
Nine Acoustic Control Parameters 

Includes 8080 Interface Software 
$395.00 plus shipping 


Order a demonstration cassette 
$2.50 postage paid 


Write for informative literature 


Calif. residents add 6% sales tax 
COMPUTALKER CONSULTANTS 
Р.О. Box 1951, Santa Monica, CA 90406 


WANTED 


Microprocessors Kit or Assembled 


ALTAIR * SPHERE * MOTOROLA 
INTEL & OTHERS 
Altairs, immediate delivery. 


Memories, 1/0 boards, chassis, power 
supplies, modems, peripherals, spe- 
cials, prom programmers, ADCS, 
DACS, GPIOS, RS232 faces, and any 
associated software. Ask about 
our complete Altair system. 
Available now. 


FORWARD INFORMATION AND/OR 
INQUIRIES TO: 


AMERICAN USED MICROPROCESSORS, 


EQUIPMENT & SUPPLY CORP. 
AT THE CHICAGOLAND AIRPORT 
BOX 515 
PRAIRIEVIEW, ILLINOIS 60069 
TELEPHONE (312) 634-0076 


For complete monthly catalog of 
items available and in stock Enclose 
$10. for six issues. Many new un- 
used items. Amazing values for 
everyone. Tested and guaranteed. 


Pictured above is the new OP-80A 
High Speed Paper Tape Reader from 
OAE. This unit has no moving parts, 
will read punched tape as fast as you 
can pull it through (0-5,000 c.p.s.}, 
and costs only $74.50 KIT, $95.00 
ASSEMBLED & TESTED. it in- 
cludes a precision optical sensor ar- 
ray, high speed data buffers, and all 
required handshake logic to interface 
with any uP parallel I/O port. 


To order, send check or money order 
(include $2.50 shipping/handling) to 
Oliver Audio Engineering, 7330 
Laurel Canyon Blvd., No. Holly- 
wood, CA 91605, or call our 24 hr. 
M/C-B/A order line: (213) 874-6463. 


Mu Mart 
І Vow York We 


NOW ON 
LONG ISLAND 


IMSAI, SWTPCo, Digital Group 
Processor Tech, Apple, OSI 
TDL-Z-80, Seals, Cromemco, 
Sphere, Tarbell, Oliver 


Magazines, books, chips, 
sockets, connectors, terminals. 


IT'S ALL HERE WAITING FOR YOU 
FRIENDLY ADVICE TOO 


New York City 

314 5th Ave 

(32nd St) 

212—279-1048 Long Island 
2072 Front St 
East Meadow NY 


516—794-0510 


NOW! 


A Computer Store in 
Burlington, MA 


Offering the complete line 
of *Altair mainframes and 
peripherals as well as boards 
& boxes, tools & instru- 
ments, books & manuals, 
supplies & media. 


The Computer Store Inc. 
120 Cambridge St. 
Burlington, MA 01803 
617-272-8770 


* Altair is a registered tradename of 
MITS, Inc. 5 


For more information circle 


101 Basic - 
Computer Games 


Our opular b 
248 pp. $7.50 [6C] 


What to Do After 
You Hit Return 


Another collection of games and 
simulations—all in BASIC—including 
number guessing games, word games, 
hide-and-seek games, pattern games, 
board games, business and social science 
simulations and science fiction games. 
Large format. 158 pp. $6.95 [8A] 


Fun & Games 
with the Computer 


Ted Sage. "This book is designed as a 
text for a one-semester course in com- 
puter programming using the BASIC 
language. The programs used as il- 
lustrations and exercises are games 
rather than mathematical algorithms, in 
order to make the book appealing and 
accessible to more students. The text is 
well written, with many excellent sample 
programs. Highly recommended." — The 
Mathematics Teacher 351 pp. $5.95 [8B 


Game Playing 
With the Computer, 
2nd Ed. 


Donald Spencer. Over 70 games, puzzles, 
and mathematical recreations for the 
computer. Over 25 games in BASIC and 
FORTRAN are included complete with 
descriptions, flowcharts, and output. 
Also includes a fascinating account of the 
history of game-playing machines, right 
up to today's computer war games. Lots 
of "how-to" information for applying 
mathematical concepts to writing your 
own games. 320 pp. 1976 $14.95 [8S] 


BYTE Magazine 


If you are considering a personal com- 
puting system now ^or later, BYTE 
provides a wealth of information on how 
to get started at an affordable price. 
Covers theory of computers, practical 
applications, and of course, lots of how- 
to build it. Monthly. l-Year sub'n $12.00 
[2A]. 3-Years $30.00 [2B] 


Games & Puzzles 
Magazine 


The only magazine in the world devoted 


to games and puzzles of every kind —, 


mathematical, problematical, 
crosswords, chess, gomoko, checkers, 
backgammon, wargames, card games, 
board games, reviews, competitions, and 
more. Monthly. 1-Year sub'n $12.00[3A] 


Games With The 
Pocket Calculator 


Sivasailam Thiagarajan and Harold 
Stolovitch. A big step beyond tricks and 
puzzles with the hand calculator, thetwo 
dozen games of chance and strategy in 
this clever new book involve two or more 
players in conflict and competition. А 
single inexpensive four-banger is all you 
ten play. Large format. 50 pp. $2.00 


Games, Tricks and 
Puzzles For A Hand 


Calculator 


Wally Judd. This book is a necessity for 
anyone who owns or intends to buy a 
hand calculator, from the most 
sophisticated (the HP65, for example) to 
ШЕ тінші “four banger.” 110 рр. $2.95 


David Н. Ahi. An anthology of games 

and simulations-—from.Acey-Deucey to 4 
Yahtzee, all їп the BASIC language. | 
Contains a complete listing, sample run, ~ 
plus a descriptive write-up of each game. і 
most popular book! Large format, : 


So you've got a 
personal computer. 


Now what? 


Creative Computing Magazine 


So you've got your own computer. Now what? Creative Computing is chock full 
of answers — new computer games with complete listings every issue, TV color 
graphics, simulations, educational programs, how to catalog your LPs on 
computer, etc. Also computer stories by Asimov, Pohl, and others; loads of 
challenging problems and puzzles; in-depth equipment reports on kits, terminals, 
and calculators; reviews of programming and hobbyist books; outrageous 
cartoons and much more. Creative Computing is the software and applications 
magazine of personal and educational computing. Bi-monthly. 

1-year sub'n $8.00 [1A]. 3- years $21.00 [1B], sample copy $1.50 [1C] 


The Best of Creative |Problems For 
Computing — Vol. 1 {Computer Solution 


David АҺ, ed. Staggering diversity of] Gruenberger & Jaffray. A collection of 
articles and fiction (Isaac Asimov, etc.),] 92 problems in engineering, business, 

mes (18 new ones with] social science and mathematics. The 
problems are presented in depth and 
Cover a wide range of difficulty. Oriented 
to Fortran but good for any language. A 
classic. 401 pp. $8.95 [7A] 


A Guided Tour of 
Computer Programming 
In Basic 


Tom Dwyer and Michael Kaufman. 


Computing (1975), all of which are now 
өш of print, 324 pp. $8.95 [6A] 


Computer Lib/ 
Dream Machine 


[Covers video: -art,: optical phenomena, 
“mathematical 


Cloth cover $10.95 [6E] 


Ted Nelson. This book is devoted to the 
premise that everybody should under- 
stand computers. In a blithe manner the 
author covers interactive systems, ter- 
minals, computer languages, data struc- 
tures, binary patterns, computer 
architecture, mini-computers, big com- 
puters, microprocessors, simulation, 
military uses of computers, computer 
companies, and much, much more. 
Whole earth catalog style and size. A 
doozy! 127 pp. $7.00 [8P] 


Computer Power and 
Human Reason 


Joseph Weizenbaum. in this major new 
book, a distinguished computer scientist 
sounds the warning against the 
dangerous tendency to view computers 
and humans as merely two different 
kinds of “thinking machines.” Weizen- 
baum explains exactly how the computer 
works and how it is being wrongly 
substituted for human choices. 300 pp. 
$9.95 [8R] 


Artist and Computer 


“Ruth - Leavitt, ed. Presents personal 
statements of 35 internationally-known 
computer artists coupled with over 160 

lates in full color and Маск & white. 


structures, — sculpture, 
weaving, and more. 132 pp. $4.95 [6D] 


Computer Science: 
A First Course (2nd Ed.) 


Forsythe, Keenan, Organick, апа 
Stenberg. A new, improved edition of 
this comprehensive survey of the basic 
components of computer science. There 
has been an updating of important areas 
such as Programming, Structured 
Programming, Problem Solving, and 
other Computer Science Concepts. The 
quantity of exercises and problems has 
been increased. 876 pp.$16.95 [7D] 


Mr. Spock Poster 


Dramatic, large (17" x 23") computer 
image of Mr. Spock on heavy poster 
stock. Uses two levels of en 
Comes in strong mailing tube. $1.50[5B] 


"This is a fine book, mainly for young 
people, but of value for everyone, full of 
detail, many examples (including 


programs for hotel and airline reser- 
vations systems, and payroll), with much 
thought having been given to the use of 
graphics in teaching. This is the best of 
the introductory texts оп BASIC."— 
Creative Computing Large format. 156 
рр. $4.40 [8L] 


A+” Creative Computing. 150 pp. 58.50 
UE] А : i 


Problem Solving With 
The Computer 


Ted Sage. This text is designed to be used 
in a one-semester course in computer 
programming. It teaches BASIC in the 
context of the traditional high school 
mathematics curriculum, There are 40 
carefully graded problems dealing with 
many of the more familiar topics of 
algebra and geometry. Probably the 
most widely adopted computer text. 244 
pp. $5.95 [8J] 


A Simplified Guide to 
Fortran Programming 


Daniel McCracken. A thorough first text 
in Fortran. Covers all basic statements 
and quickly gets into case studies ranging 
from simple (printing columns) to 
challenging (craps games simulation). 
278 pp. $8.75 [7F] 


Understanding Solid 
State Electronics 


An excellent tutorial introdüction to 


transistor and diode circuitry. Used at 
the TI Learning Center, this book was 
written for the person who needs to 
"understand electronics but can't devote 
years to the study. 242 pp. $2.95 [9A] 


Microprocessors 


A collection of articles from Electronics 
magazine. The book is in three parts: 
device technology; designing with 
microprocessors; and applications. 160 
pp. 1975 $13.50 [9J] 


Microprocessors: Tech- 
nology, Architecture 
and Applications 


Daniel R. McGlynn. This introduction 
to the microprocessor defines and 
describes the related computer structures 
and electronic semi-conductor processes. 
Treats both hardware and software, 
giving an overview of commercially 
available microprocessors, and helps the 


, user to determine the best one for 


him/her. 240 pp. $12.00 [7C] 


] Creative Computing 


Catalogue 


Zany  l2-page tabloid newspaper/ 


‚ catalog lists books, magazines, art prints, 


and T-Shirts: A conversation piece even 
if you don't order anything. Free. [5A] 
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Please send те the following: 
ап. Cat. 


CREATIVE COMPUTING, Dept. B 
P.O. Box 789-M, Morristown, NJ 07960 


Description 


Books Shipping charge $1. 


NJ Residents add 5% sales tax 


Price 


00 USA, $2.00 Foreign 


П Cash, check, М.О. enclosed TOTAL 

П BankAmericard Card No. 

O Master Charge j Expiration date 

Name 

Address 

City State Zip ———— 


ALTAIR & IMSAI MOTHERS 
DESERVE BEAUTIFUL 8K BABIES 


rom VECTOR GRAPHIC 


POCKET 


DATA 
TEA MANAL 


A Suggestion is Fulfilled 


In last month’s new products section, a 
touch tone frequency generator was sug- 
gested as a possible portable product to be 
used as a portable data terminal. Well, a 
company called Executive Devices has pro- 
duced a product which incorporates such a 
frequency generator and can be easily used 
in the portable terminal mode. This battery 
powered hand held device generates the full 
16 combinations of tones possible with the 
touch tone encoding technique, and inter- 
faces with the telephone network through an 
acoustic coupler. There are two models 
available: 

Pocket Data Terminal PDT-700 is $49.95, 

postpaid, and is the simple tone gener- 
ator version. (Kit version $39.95.) 


Pocket Data Terminal PDT-1000 is ALTAIR & IMSAI COMPATIBLE 8K RAM 
$89.95 postpaid, and is an extended SPECIFICATIONS: 
Access Time: 500 ns max. current required « 200 mA/1024 
words max. 
Memory Chip: low power static RAM processed to mil. std. 883 
Voltage supply: +5V to + 10У 


Address Select: Dip switch accessable from top of board—no 
need to remove board to relocate 


Power Regulators: 4 ea. 7805 
Wait States: NONE! CPU runs at maximum speed 


Buffered address and data out lines 
Buffer disable line for transparent loader 


CLIP & ORDER TODAY 


Order your 8K RAM kit for only VECTOR GRAPHIC 

$239.00 +6% Calif. sales tax P.O. BOX 4784 

.03% handling. $335.00 assem- THOUSAND OAKS, CA 91359 
bled, includes sockets. TEL: (213) 889-9809 


[1 SEND. 8K RAM BOARDS TODAY 
[1 CHARGE TO MY CREDIT CARD. 
B of A No. exp. dt. 


C] М.С. Мо. tap it. 
Signature 


Name 
Address 


STANDARD & CUSTOM ENCLOSURES 
FOR 


State — Zip 
INTRODUCTORY OFFER 


THE COMPUTER CO. OF THE FUTURE 


:————————————————— 
Lec сасыса сы аа 5С P——— ——— lesa 


COMPLETE KEYBOARD HOUSINGS, CRT'S & ETC. 
--- CAPABILITIES IN --- 


Kydex 100 - Plexiglass - Lexan 
PVC - ABS 


FOR FURTHER INFORMATION WRITE OR CALL: 
P.O. BOX 4784 

THOUSAND OAKS, CA 91359 
TEL:(213) 889-9809 


СОЗ GRAPHIC ІПС. 


Thermodyne Plastics, Inc. 
11495 Lenexa Drive 
Olathe, Kansas 66061 


913-492-7352 
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feature model with a nonvolatile user 
programmed memory: of seven digits 
for automatic dialing of a frequently 
used number. (Kit version $69.95.) 


Of course the auto dial product by itself 
won't do much for people stuck out in a 
country telephone exchange with relays and 
stepper switches for dialing, but any com- 
puter equipped with an auto answer func- 
tion to a telephone port can receive and 
decode the touch tone frequencies of this 
device. For the home hacker, this can be 
accomplished by tapping into the audio 


Real Time Programming, Anyone? 
(or How to Make a Perpetual Audio 
Visual Date Book) 


COMPTEK, a company located at POB 
516, La Canada CA 91011, has come up 
with just the thing needed to implement the 
application in the subtitle of this new 
products story. In order to implement a real 
time process such as an appointment book, 
some means of noting time and date digitally 
for each hour of the day, every day of the 
year, is required. 

The way to accomplish this time measure- 
ment is to use this $98 real time clock board 


section speaker outputs of a commercial 
ATT approved phone answering device. The 
auto answer logic is built into such a phone 
answering device, so all the computer has to 
do is to test the cassette motor control line 
and listen through a bank of tone sensitive 
filters for the frequencies involved. Ac- 
cording to verbal reports, several individuals 
are already at work automating such home 
functions as lighting control through remote 
ports accessed in this manner; there ought to 
be a market niche for the commercial 
answering equipment needed (to plug into 
an Altair or other computer main frame). 


for the Altair or IMSAI computers. The 
board contains a conventional LSI clock 
chip, the National Semiconductor 
MM5318N shown in the photograph (the 
largest plastic package integrated circuit). 
The clock interfaces to the Altair in either a 
programmed ІО mode, or an interrupt ІО 
mode of operation. For clock interrupts, the 
board can be programmed to interrupt 60 
times per second, once per second, once 
every 10 seconds, once per minute, once 
every 10 minutes (radio amateurs take note), 
once per hour, or twice per day. Also 
programmable through the board are the fast 
setting modes of the clock chip. 

The microcomputer system treats the 
clock as a peripheral, and reads the time 
directly in a 24 hour HH:MM:SS format, 
BCD encoded. For the user wanting to 
implement the date book, some software 
information management structures will of 
course have to be created to use it, but the 
hardware of this board is a key element 
which makes such a system possible. 
Imagine: your computer with its audio and 
video output devices nagging you to get up, 
go on vacation, keep the appointment with 
the dentist, etc.m 


Is This a Programmable Calculator 
or Computer System? 


Here is the latest Hewlett-Packard innova- 
tion, the flexible disk drive for the desk top 
calculator. The disk drive plugs into the HP 
9825 desk top programmable calculator, to 
provide mass storage capability far beyond 
the built in data cartridge drive. The new 
product comes in two forms. The 9885M 
master disk drive is priced at $3900, and the 
98855 slave (up to three of which may be 
used with one 9885M controller) is priced at 
$2500. The 9825 can handle eight of the 
9885M units, making it possible for the 
extreme case of 32 disk drives run by one 
calculator. Since each disk holds 468,480 
bytes of data, in the extreme, the calculator 
could have 14,991,360 bytes of on line 
random access storage — hardly a mere desk 
top calculator's worth of mass storage. 

The disk option will prove a most useful 
feature for this calculator, which is pro- 
grammed in a high level language command 
system. The disk option extends the software 
of the calculator to include a directory 
feature for up to 320 named files on disk. 
АП operations are done in a write-then verify 
mode to ensure reliability. 

Hewlett-Packard is located at 1501 Page 
Mill Rd, Palo Alto CA 94304.u 
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Breadboard Kit Including 
Slit-N-Wrap Tool 


Vector Electronic Co, 12460 Gladstone 
Av, Sylmar CA 91342, has introduced this 
new modular breadboarding kit containing 
36 different parts. The list includes terminals 
sockets, perforated circuit boards, wire, 
tools and many other items designed for 
custom wrapped wire circuit construction. 
The kit is designated 41X by the company, 
and the total cost of parts for the’ kit is 
lower than the catalog prices when ordered 
separately. 

The kit contains the P180 Slit-N-Wrap 
tool to wrap and strip insulated wire found 
on a spool. This tool is a must for wrapping 
of extended bus structures, since there is no 
time consuming stripping or measuring to be 
performed. //’m using the P180 to complete 
а bus structure of backplane connectors on 
my homebrew system which has been par- 
tially assembled for months due to the 
inconvenience of the cutting and stripping 
with conventional wire wrap ... CH] 

In addition, the kit contains ten 16 pin 
DIP sockets, five types of wrap posts, and 
Vectorboard socket cards with and without 
printed circuit pads and buses. Also included 
are extruded aluminum frames to support 
the circuit board as a chassis. 

The price of this omnibus kit of Vector's 
excellent products is $56.50, and it is 
available from stock. The 41X Multi-Conn 
Kit can be ordered directly from the factory 
(write to the attention of “Dept X"). Vector 
products are frequently found at retail com- 
puter stores, and retailers of the Vector line 
may find this an excellent "gift" product for 
the walk-in trade.m 


E&L Instruments Increases 

Memory and Interface Capabilities 

of Their MMD-1 Microcomputer with an 
Accessory Board 


A new accessory board model MMD-1/MI 
with extra RAM memory, Teletype inter- 
face, and audio cassette interface has been 
added to the E&L Instruments line. The 
MMD-1/MI simply plugs into the built in 
card edge connector on the MMD-1 and 
mounts on top of the unit as shown in the 
photo. 

A MMD-1/MI accessory board completely 
assembled and tested, sells for $200. In kit 
form with all parts for assembly, the price is 
$150. The MMD-1/MI has the following 
features: 

€ 2K byte programmable memory 

capability (1 K supplied). 


ENIGMAS-1 
COMPUTER GAMES IN BASIC 
PRICE $8.00 


“. 
. 
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"жа . . . 
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ENIGMAS-1 IS A BOOK OF COMPUTER GAMES 
TAKEN FROM MY CATALOG 
THE PROGRAMS IN THIS BOOK ARE: 
GONE FISHING — GO FISHING TO MAKE 
MONEY 
CONCENTRATION — MATCH THE HIDDEN 
NUMBERS-TWO CAN PLAY 
SLOT-MACHINE — IT'S EASY TO LOSE YOUR 
MONEY 
CRAPS DICE GAME 
WITH DICE PRINT-OUT — SHOOT CRAPS AND 
SEE THE DICE 
TANK ATTACK — TRY TO DEFEND YOURSELF 
STAR SHIP 
(STAR TREK TYPE GAME) — SHOOT SOME 
KLINGONS 
SHERLOCK HOLMES 
LOGIC GAME — CHASE PROFESSOR MORI- 
ARTY 
ALL MY PROGRAMS IN BASIC HAVE BEEN 
WRITTEN TO RUN IN MOST ANY BASIC 
COMPILER-INTERPRETER WITHOUT ANY 
CHANGES. 
THEY WILL RUN UNDER ALTAIR 4K OR 8K 
BASIC AND MOST ANY OTHER BASIC СОМ- 
PILER-INTERPRETER PROVIDED YOU HAVE 
ENOUGH MEMORY TO RUN THEM. 
PRICE $8.00 PPD. SORRY NO COD'S 
B. ERICKSON 
P.O. BOX 11099 
CHICAGO, ILL. 60611 


JEA DEVELOPMENT LABS 


P. O. Box 2345 
W. Lafayette, IN 47906 
{317) 463-7167 


14 watt carbon film resistors 
5 percent, 50 per value min. 


V? watt carbon comp resistors...$0.02 
10 percent, 50 per value min. 


No-Nik wire strippers 
10,12, 14,16, 18,21,23,25,28,31 
34,37,44 or 54 thousanths 
wire diameter 


Carbide PC board drills 
wire size: 55 - 65.... 
66 - 70. 
ee 7822. 
76 - 78. 


Spec sheets are available. 


We would be pleased to send you a 
‘GOODIES’ catalog listing all kinds of 
hard to find products including: Molex, 
Bishop Graphics, AMP, CDC manuals 
and forms, PC drills and mills, elec- 
tronics tools, PC board manufacturing 
supplies, resistors, and semicon- 
ductors. 


TURN ON 
WITH COMPTEK 


Now your micro can control AC 

power outlets with COMPTEK's NEW 

P3200 Power Control System. 

* 1 to 32 independently address- 
able control channels 

* Remote power control units — 
no AC power on logic board 

е Optically isolated, current lim- 
ited, low voltage control lines 

e Accessible through most BASIC's 

e ALTAIR and IMSA! compatible 


Write today for more details! 


comptelk. 


“Real World Electronics” 


Р.0. Box 516 
La Canada, CA 91011 


HEY, ALTAIR... 
GOT THE TIME? 


If not, you need COMPTEK’s NEW 

012400 Real-time Clock. 

* Self-contained hardware clock 

e Can be set and read by BASIC 

* Programmable interrupts 

е Top quality board, components, 
and 1.С. sockets 

e ALTAIR and IMSAI compatible 


е Uses: 24 hour clock 
Software timer 
Event timer 


KIT — $98 ASSEMBLED — $135 


comptek_ 


“Real World Electronics” 


Р.0. Box 516 
La Canada, СА 91011 


8,192 Х 8 BIT STATIC MEMORY 
EXCEPTIONALLY LOW POWER 


jen 


KIT $295.00 
*ALTAIR 8800/IMSAI 8080 BUS 
COMPATIBLE 
“FAST 215 nS-FULL SPEED—FOR 
Z80 ALSO 
*EXCEPTIONALLY LOW POWER— 
LESS HEAT 
*LESS THAN OTHER "LOW 
POWER” MEMORY 
*BATTERY STAND-BY 
CAPABILITY 
*ALL SIGNALS TO MOS DEVICES 
BUFFERED 
*SOCKETS FOR ALL IC'S 
PROTOTYPING BOARD 
LOW PROFILE IC SOCKETS 
EDGE CONNECTORS 
DB25 CONNECTORS 


SHIPPING EXTRA, ADD $2.00 
NJ RES. ADD 5% SALES TAX 


ELECTRONIC CONTROL TECHNOLOGY 
Р.О. Box 6, Union, New Jersey 07083 


NOW! 


A Computer Store in 
Windsor Locks, CT 


Offering the complete line 
of *Altair mainframes and 
peripherals as well as boards 
& boxes, tools & instru- 
ments, books & manuals, 
supplies & media. 


The Computer Store 
63 5, Main St. 
Windsor Locks, CT 06096 
203-871-1783 


*Altair is a registered tradename of 
MITS, Inc. 


For more information circle, 


The Briefcase Computer Concept, Revisited 


This neat little package of computing 
power, the DE68, made by the Digital 
Electronics Corporation, 415 Peterson St, 
Oakland CA 94601, is intended for use as a 
stand alone computer system in a briefcase. 
The system is completely self-contained, 
with the following characteristics: 


* 6800 microprocessor. 

* alphanumeric keyboard (96 character). 

* miniature electronically controlled 
digital cassette system with 100K 
byte on line capacity. 

* 20 column wide alphanumeric display. 

ө 20 column = alphanumeric printer 
(optional). 


Need a Fast Microcontroller? 


Signetics Corp, 811 E Arques Av, Sunny- 
vale CA, has introduced a new high speed 
microprocessor component called the 
8X300, which is "optimized for control 
operations," This is a Schottky bipolar 


@ Teletype interface (20 тА current 

loop). 
е Paper tape reader control for ASR33 
Teletypewriters. 

* Audio cassette interface. 

€ Sockets to accept up to 1 K PROM or 
ROM. 

The addition of the MMD-1/MI board to 
the basic MMD-1 Microcomputer increases 
the system memory capacity to 2.5 K pro- 
grammable memory and 1.5 K PROM or 
ROM. The Teletype interface and audio 
cassette interfaces allow easy and inexpen- 
sive data storage and retrieval. The 
MMD-1/MI is now available from E&L 
Instruments and from all E&L Instruments 
stocking representatives. E&L. Instruments is 
located at 61 First St, Derby CT 06418.m 


€ 5.5 K byte PROM operating system 
with mnemonic translator, tape com- 
mands, memory manipulation fea- 
tures, breakpoints, single stepping of 
programs, traces, etc. 

ә ]K bytes of user programmable 
memory standard, optional expansion 
to4K,8Kor32K. 


This is a completely self-contained micro- 
computer system which could be equally 
well used as a personal computer, an educa- 
tional tool oriented to assembly level pro- 
gramming, or custom applications interfaced 
through its IO expansion connector (to the 
right of the processor card seen in the 
photograph). The DE68 price, completely 
ready to go as seen in the photograph, is 
$3500 (including the printer peripheral 
option) with delivery 60 days after receipt 
of order.m 


Star Trek in BASIC? 


Atlantis Consultants, РОВ 8493, Salt 
Lake City UT 84108, has come up with two 
Star Trek programs, written in BASIC, 
which are available now at $12.50 for the 
set. Included in the literature accompanying 
the programs, according to a letter from Earl 
Smith of Atlantis, are memory requirements, 
operational instructions, and tips and 
patches to help tailor the programs to any 
size system. These programs are accom- 
panied by a one year warrantee against 
programming and typographical errors.m 


processor with a simple two operand instruc- 
tion set and a single instruction execution 
time of about 250 ns (operating on 8 bit 
data). The processor is available from stock 
at distributors for a quantity of 100 price of 
$86.75. No single quantity price was quoted, 
but based on comparable pricing strategies in 
the marketplace, we would expect the single 
unit price to a hacker to be below $250. 
What can a savvy BYTE reader do with a 
chip like this? 

Well, look at the vector graphics problem, 
and consider design of an ROM programmed 
vector graphics processor. This machine |15 
fast enough to do both the timing operations 
of a vector graphics generator, and the 
storage housekeeping for refresh. Build a 
custom machine for the 256 by 256 vector 
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Printed Circuit Board 
Hackers Take Note 


Two new etched circuit board kits from 
Vector Electronic Co, 12460 Gladstone Av, 
Sylmar CA 91342, facilitate rapid produc- 
tion of quality circuit boards without expen- 
sive and time consuming processing with 
cameras and darkrooms. The kits, model 
numbers 32X-1 and 32XA-1, contain posi- 
tive resist coated circuit boards, bare copper 
clad boards, and all materials necessary for 
fabricating circuit boards by the direct art 
then etch process, and also by the positive 
photo resist process. 

For direct processing, circuit patterns are 
applied directly on bare copper laminated 
circuit boards, using the acid resistant rub 
transfer artwork sheets and other art mate- 
rials contained in the kits. The sheets have 
patterns for 40, 24 and 16 pin dual in line 
packages, flat packs, lines in 5 widths, pads 
in 7 diameters, edge contacts in 2 sizes, 
alphabetic and numeric markings, and many 
miscellaneous coupling pad configurations. 

The rub transfer patterns also may be 
used for making one to one size custom 
positives on the clear Mylar film supplied. 
This is then used to photo pattern the 
copper clad laminated boards coated with 
photosensitive etch resist, Vector's positive 
photo resist eliminates the need for photo- 
graphic conversion of master artwork to 
negatives. The positive film is placed on the 
board, and exposed to a full or partial 
ultraviolet light source. 

Exposure time requires approximately 
four minutes with either a GE "sun lamp," a 
commercial exposure lamp, or direct sun- 
light. A six ounce bottle of developer in 
solution accommodates about 600 square 
inches of sensitized surface. 

The exposed and developed boards are 
etched in the ferric chloride solution and 
chemical tray supplied. The simple devel- 
oping and etching process takes about 20 
minutes. Following washing, the board is 
ready for use. 

Vector etched circuit kits are useful for 
both engineering and experimental circuit 
board fabrication, Existing full scale artwork 
may be copied directly with the supplied 
tracing and artwork materials. 

The Vector 32XA-1 kit will make seven 
printed circuit boards, and is priced at $28. 
The 32X-1 sample kit makes two boards, 
and is priced at $11.50. m 


graphics application, with an intelligent re- 
fresh command language and a communica- 
tions discipline for talking (as a peripheral) 
to your main microprocessor. 

Take a look at the vertical micropro- 
gramming problem: emulating the instruc- 
tion set of a known "'nice" processor with 
lots of software. The 8 bit data paths of this 
machine, plus the high speed and internal 
scratchpad facilities should allow micropro- 
gramming hackers a very flexible alternative 
to the bit slice approach. According to the 
press release, it is "possible for 8 bit parallel 
data to be rotated or masked, to undergo 
arithmetic or logical operations, and then to 
be shifted and merged into any set of from 
one to eight contiguous bits at the destina- 
tion — all within one 250 ns cycle." A glance 


at the block diagram for the processor 
reproduced here corroborates this statement. 

We'll be looking forward to some articles 
by readers on the use of this sort of chip to 
implement high performance homebrew rigs 
in the near future, to say nothing of the 
possibility that such a chip could be used as 
a key component of a true "high level 
language" machine implemented at low 
cost. 


Attention, Commercial and Industrial 
Graphics Users 


Here is a state of the art graphics product 
designed for OEM customers only, the 
model 619 Storage Display Monitor made by 
Tektronix Inc, Beaverton OR. OEM only 
means that Tektronix is not interested in 
selling to “unsophisticated” users in this 
case. But as an example of a high resolution 
vector graphics display, all us individual 
users will be waiting with mouths watering 
for the introduction of smaller scale but high 
resolution units for personal systems. Here is 
what the state of the art price of $7125 
(single quantity OEM) gets a systems 
engineer with graphics in mind these days: 


The model 619 is а 19 inch (48 cm) 
direct view storage tube display which is 
designed for high density flicker free 
graphics. The 619 provides stored displays of 
combined alphanumeric and graphic infor- 
mation from analog sources and digital 
computers, with engineering data provided 
so that the OEM systems builder has full 
control in developing analog or computer 


interfaces to utilize the capability of the 
619. 

The storage tube of this device is used to 
achieve high density graphics without the 
need for providing expensive memory de- 
vices. But the bistable storage tube has two 
modes of operation: The storage mode 
allows conventional storage graphics which 
gives high density flicker free pictures built 
up over considerable periods of time; a 
second refresh graphics mode allows a par- 
tially stored and partially refreshed display 
to be generated. Only the fixed portion of 
the display is stored with storage graphics 
technology, and a variable refresh graphics 


portion covers the moving stuff. In a Space 
War game, this terminal would excel since an 
intricate background map could be con- 
structed using the storage graphics tech- 
nology of the instrument, with the variable 
graphics of the space ships, torpedos, 
players, etc, being provided by the refresh 
portion. The capacities of the machine in the 
refresh mode are 3200 inches of stored 
vectors and 630 inches of refreshed vectors. 
One can expect that those lucky BYTE 
readers who have access to a Tektronix 619 
through a research, commercial or industrial 
job situation will have a field day with this 
machine for interactive games. 


If you want a microcomputer 


with all of these standard features... 


* 8080 MPU (The one 
with growing soft- 
ware support) 

* 1024 ByteROM 
(With maximum ca- 
pacity of 4K Bytes) 


connectors 
* Comprehensive 


Intel 8080 User's 
Manual 


* Complete with card 


User's Manual, plus 


* 1024 ByteRAM * Completely 
(With maximum factory assembled 
capacity of 2K and tested— not 
Bytes) a kit 

* TTY Serial 1/О * Optional ac 


* EIA Serial МО 
* 3 parallel I/O's 
* ASCII/Baudot 
terminal com- 
patibility with TTY machines or video units 
* Monitor having load, dump, display, insert 
and go functions 


cessories: Key- 
board/video 
display, audio 
cassette modem 
interface, power supply, ROM programmer 
and attractive cabinetry... plus more options 


to follow. The HAL MCEM-8080. $375 


.. ethen let us send you our card. 


HAL Communications Corp. has 
been a leader in digital communi- 
cations for over half a decade. 
The MCEM-8080 microcomputer 
shows just how far this leadership 
has taken us...and how far it 

can take you in your applications. 
That's why we'd like to send 

you our card—one PC 

board that we feel is the 
best-valued, most complete 


microcomputer you can buy. For 
details on the MCEM-8080, write 
today. We'll also include compre- 
hensive information on the HAL 
DS-3000 KSR microprocessor- 
based terminal, the terminal that 
gives you multi-code compati- 
bility, flexibility for future 
changes, editing, and a 
convenient, large video 
display format. 


HAL Communications Corp. 
Box 365, 807 E. Green Street, Urbana, Illinois 61801 
Telephone (217) 367-7373 


COMPUTERS ARB NO GOOD 


without Software. At last a BASIC SOFTWARE LIBRARY is available ! | ! 


Volumes I & II available immediately; III & IV in January. * Vol. 
RECREATIONAL, source codes, instructions, etc. 300 pg. 


I - BUSINESS & 


* * Vol. II - ENGINEERING 


STATISTICS & PLOTTING plus BASIC Reference conversions, 250 pg. Each written in 


BASIC, 


or send SASE for info.TO: SCIENTIFIC RESEARCH 
PO Box 2096; Ashland, VA 23005. * Volume Discounts available * 


immediately executable in ANY computer; micro or mini. SPECIAL CHRISTMAS 
OFFER Vol I & II 


ванкамеасао 9^ for air mail, 


$39.95; else $25.95 ea. Add $2 ea. for hndl 


master charge 


ти мтелвлик CARD 


Dealer and distribution inquiries welcome. 
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Classified Ads for Individuals and Clubs 


FOR SALE: Complete VIATRON System 21, 
includes printing robot, comm adaptor, also many 
tapes. Unit in perfect operating condition. Will 
consider throwing in the IBM Selectric Model 72 
typewriter. Want $500 for all except Selectric. Will 
trade for video display board and memory for 
IMSAI, or small video terminal. Tom French, c/o 
Philips Data Systems, 3320 Holcomb Bridge Rd, 
Norcross GA 30092. 


FOR SALE: Hewlett-Packard HP-185B oscillo- 
scope with 187C dual trace plug in. Triggered 
sweep, DC-1000 MHz sampling. Internal DC level, 
50 MHz sine wave, pulse calibration signals. One 
knob cracked but scope works good. $300. Mike 
Turner, Rt 2, Roberts St, Fletcher NC 28732. 
(704) 684-2112. 


WANTED: | am looking for information on a 
FREIDEN "5610 Comptyper.'' (1) Pin outs on the 
aux output plugs of this unit. (2) Necessary data to 
interface this unit with a BOBO system. K9BJN P F 
Collins, 1611 W Madison St, Kokomo IN 46901. 
1317) 452-0265. 


WANTED: New or used LA36 DECwriter Il. | have 
written several programs in Altair BASIC, For 
information send $0.25 to Timothy G Roscoe, 153 
Dorman Dr, Elizabeth PA 15037. 


WANTED: Need schematics and manuals for 
DURA MACH 10, also tech data for ITEL System 
3016SQD and/or DURA  typewriter models 
8123124 and 133038. | have considerable data 
(130 pages) on other models to swap or sell. | wish 
to communicate with other users and parts sources. 
Ronald Jenkins, 4490 Sirius Av, Apt 4, Lompoc 
CA 93436. 


FOR SALE: IBM 2315 disk cartridge (S/N 22721) 
perfect condition; make offer. Rudy Wrobel, 
12725 W 55 Terrace, Shawnee KS 66216. 


FOR SALE: MITS 88-4MCD 4 К dynamic memory 
card. Fully assembled and tested by MITS $190; 
88PIO parallel IO port with cable and connectors, 
assembled and tested $60. Complete set of Mark-8 
boards with one extra memory board all brand new 
plus highly regulated Precision Systems power 
supply *5 М/8.5 А -12У/20А adjustable to 
—9 V, includes Radio Electronics Mark-8 blurb all 
for $110. Steve Caldara, 965 E State St, Ithaca NY 
14850. (607) 273-9234. 


FOR SALE: MITS Comter 256 terminal with 
acoustic telephone coupler, assembled and opera- 
tional. Also, three 4 K dynamic memory boards 
and an 88-ACR cassette interface, all assembled. 
Steve Fritts, 2920 Bellevue St, Knoxville TN 
37917, (617) 525-5407. 


FOR SALE: I have a supply of new INTEL and TI 
8080A microprocessor chips for $25 each. These 
can be used to update your Altair computer, to 
control intelligent peripherals, or for experimental 
circuits. Sockets and specs are available if re- 
quested. G Lorenc, Box 710 LU, Lockport IL 
60441, (815) 838-4930. 


WANTED: Low cost new or used terminal and/or 
acoustic coupler for private use. Write Rob Lufkin, 
Lodge 9, RFD 1, Box 52, Charlottesville VA 
22901. 


FOR SALE: Zilog 2-80 third generation micro- 
processor chips. $95 each including shipping and 
handling. We are a club and will purchase these 
chips from the manufacturer at quantity discount 
prices. We need a minimum of 25 orders. For a 
description of the 2-80 see the August 1976 
BYTE, page 34. Send orders to Kristopher Kafka, 
166  Marshland На, Apalachin NY 13732. 
(607) 625-2972. Sorry, no CODs, по, credit cards. 


FOR SALE: SCM computer terminal in perfect 
working order. Complete with cables and well- 
filtered power supply. All in working order. SCM 
No. 603601 schematic No. 4391171. Can easily be 
converted to IO hard copy printer. You рау 
shipping and $150. Will trade. Call or write Wallace 
Hurley, 2753 Parkside Dr, Fremont CA 94536. 
(415) 792-8589. 


FOR SALE: Limited supply of core memories 
from major computer manufacturer with spec 
sheets. 8 X 64 X 64, $15; 16 X 64 X 64, $30; 17 X 
64 X 64, $35; spec sheets, $0.75. Include shipping, 
excess refunded. Jim Kuiper, 542 Linden Ln, Ann 
Arbor MI 48103. 


FOR SALE: FRIDEN printing terminal 1970, 
several available. 12.2 or 14.7 cps — full ASCII 
font — half duplex with breakin — 14% paper; 140 
print positions. Quiet, mechanically simple, cast 
aluminum housing. Size 21" X 23" X 11”. Room 
for 15 3" X 5” PC cards. Parallel data input and 
output. Schematic for electronics to perform shift 
decode, repeating and logic interface with UART 
included (standard TTL). Mechanically overhauled, 
excellent operating condition $250 delivered, New 
York-Boston. J Colter, POB 122, Short Beach CT 
06405. 


WANTED: ITT Asciscope repair manual and 
schematics. George Ahmuty, 60111 Wendy Ln, 
Westport CT 06880. (203) 227-B534. 


FOR SALE: Altair 8080, PTC Motherboard, 
IMSAI cassette interface, 4 К and 1 К RAM, 4K 
EROM presently burned with assembler-monitor- 
editor, MITS quad parallel interface board, TI 
ASCII keyboard, PTC VDM-1 with expanded 
software and video monitor. Complete system: 
$1600. С б Hullquist, (615) 727-7793/8437, Box 
H, Mountain City TN 37683. 


ENTREPRENEUR seeking creative electronics 
“wizard” as partner in new moonlighting business 
venture to develop computer products for high 
potential home and small business markets. Must 
be located in San Francisco area. If interested, 
please write Н Lum, 20661 Marion Rd, Saratoga 
CA 95070. 


FOR SALE OR TRADE: Friden Flexowriter 
Model SFD. Has 8-level printer, paper tape reader, 
paper tape punch and keyboard. Excellent con- 
dition. $300 or will trade for TVTI or ТУТИ. Call 
or write Bill Dawson, 316 21st St, Apt No. 4, 
Virginia Beach VA 23451. (804) 425-4411 (days), 
(804) 422-5921 evenings. 


SWAP OR SELL: One (1) tape punch machine 
with keyboard, 75 cps punch and Burrough dis- 
play. $400. Four (4) 75 cps punch mechanisms and 
driver cards. $75 each. Three (3) high performance 
stepper motor systems (2 motors and power supply 
and control logic). $300 each. Honeywell 3C 
cards — three (3) each: FC320 and BC320; one (1) 
DK320. Call after 5 PM (617) 369-2075. Albert 
Spitzak, 113 Everett St, Concord MA 01742. 


FOR SALE: І have an HP-65 calculator to sell 
before 1 buy a computer, since having both would 
take too large a byte out of my savings. $700 buys 
it. Joseph R Danek, 3945 E Birchwood Av, 
Cudahy WI 53110. Call (414) 769-7489 between 9 
and 12 AM CST. 


FOR SALE: Issues 1-12 of BYTE, good condition. 
Best offer above cost of magazine. Robert Camp- 
bell, 4324 Walker St NE, Cedar Rapids 1A 52402. 
(319) 393-4191. 


FOR SALE: Altair 8800 computer, fully assern- 
bled and tested, with 1 K static RAM, $500 plus 
shipping and handling. R A Stook, Cherry Dr, 
Souderton PA 18964. Telephone: (215) 723-4766. 


FOR SALE: MiTS VLCT (Very Low Cost Termi- 
паі), complete except for case, $75; 4 К memory 
board for Altair 8800, fully assembled and work- 
ing, $95; tape cartridges for ІВМ MTST typewriter, 
$5 each or swap for ? Used Altair 4-slot mother- 
board in reasonable condition, $10. Jim Einolf, 
3900 Fox Dr, Loveland CO 80537. 


FOR SALE: STELMA Model 2400 data modem. 
1200 and 2400 bps over HF radio (used on 
APOLLO project for long haul data transmission). 
2 units, spares, manual $250. Frank Gentges, 3512 
Orme Dr, Temple Hills MD 20031. 
(301) 894-2613. 
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FOR SALE: MOS Technology КІМ-1 тісто- 
computer system. Purchased in March from MOS 
for $245; completely checked out. $175, including 
5 V and 12 V power supply. Built to MOS specifi- 
cations, and complete documentation. KIM-1 has 
hex keyboard, LED display, 1 K RAM, PROM- 
resident executive, TTY, audio tape, and BOS 
interfaces. Larry Hill, (617) 475-4700 or 
(617) 646-6428; 163 Waverly St, Arlington MA 
02174. 


FOR SALE OR SWAP: EIS telewriter-keyboard/ 
printer unit, 8-level code {ASCII}, 110 baud, full 
duplex, TTL ievel output. Operating condition, 
may need some adjustments. W/some data $295. 
Also some fully ASCII encoded keyboards $50. 
Money order to: Bill Dumbleton, 1713 Webster St, 
Omaha NE 68102. (402) 341-1529 days, 551-0577 
evenings. 


FOR SALE: 16 K words by 9 bit core memory 
modules (10" X 12" X 4"). Needs only TAL 
interface and power supplies (+5, —5, and +30 
volts). 1 us read/write cycle time capability. Com- 
plete documentation available. For additional 
information write to Dave Bowman, 5437 W Tierra 
Buena Ln, Glendale AZ 85306, (602) 978-0332. 


TRADE: Will trade by BYTE collection (issues 
1-12, excellent conditon) for a complete set of 
QST magazines from January '75-June ‘76 inclu- 
sive. Jeff Stern, 809 Flanders Dr, Valiey Strm NY 
11581. (516),791-7471. 


FOR SALE: FABRITEK соге stack, model 
999-6155-00-B 16 K words by 24 bits, no other 
data, Will include 34 type SN7528 sense amps. 
Best Offer over $200 takes it. Contact: Steve 
Marum, 116 Western Hills Dr, Apt 136-J, Howe, 
TX 750589. (312) 532-5292. 


PARTNER(S) for microcomputer store wanted in 
Texas, Okia, Colo, or NM. I will finance up to one 
half interest in store; you must have direct micra- 
computer experience. Dr M E Reed 1417 North- 
gate Sq B-12, Reston VA 22090. (703) 437-5992. 


FOR SALE: Assembled SWTP 6800 CPU board 
with support information consisting of SWTP 6800 
User's Manual, Motorola 6800 Programming 
Manual, and 6800 Applications Handbook. Will seil 
for $260 or best offer. Mark-8 CPU, Address latch, 
and Input multiplex boards, includes most TTL 
and resistors and caps, $30 or best offer. 18 slot 
card cage used — great condition, with 18, 22 pin 
WW and 17, 100 pin WW Amphenol card edge 
connectors, $25. Tim Tibbott, 714 N Nottawa, 
Sturgis Mi 49091. 


FOR SALE: Populated MIL MOD 8 boards: 8-2 
TTY board $10. 8-3 Control board $10. 8-6, 8-7 
ІЮ boards $10 ea. 8-1 CPU board $18. Unpopu- 
lated 8-4 1702 type PROM board $5. C-MOD 8 
MOD 8-9 board with 8316 2K X 8 bit ROM 
containing 8008 operating system $30. Plus much 
information on the MOD 8 system. All boards built 
with PRIME parts. R DeHoff, Smith Hall, Kent OH 
44242, 


FOR SALE: High speed paper tape punch, Tele- 
type Corp (BRPE) with maintenance manuals and 
parts manual. Eight channels at 110 characters per 
second. Very good working condition. Best offer. 
Ronald Howland, 23 Sumner St, Milford MA 
01757. 


AVAILABLE: Copies 1-9 of BYTE (two copies of 
issue 2}. Any offer will be considered but would 
prefer to sell all in one transaction. Contact: John 
R Kaser, 7500 NW Peavy Arboretum Rd, Corvallis 
OR 97330. (503) 745-5703. 


FOR SALE: 8008 based operating system fea- 
turing 11 human-engineered commands, allows full 
control of loading/examining memory, octal or hex 
dump, execution initiation, and read/write/control 
of cassette tape storage. Included are 47 pages of 
source code, operating instructions, and schematics 
for 256 level hardware pushdown stack, serial- 
Parallel interface, PROM interface. $7.50 postpaid. 
If 15 orders are not received within 30 days from 
publication of this ad, your check will be returned 
uncashed. William E Severance Jr, Center Lovell 
ME 04016. (207) 925-2271. 


БСОМРОЛТЕН 
PROGRAMMING 
COURSE 


Free description and outline of 
Modu-Learn TM Ноте Study 
Course in microcomputer pro- 
gramming. Hundreds of pages of 
text with examples, problems, 
and solutions. Prepared by pro- 
fessional design engineers using 
the best software design tech- 
niques from structured program- 
ming and practical experience 
with microcomputers. Presented 
іп a modular sequence of 10 
lessons oriented for the new 
programmer. Extensive reference 
material you will use long after 
you become ап accomplished 
microcomputer software designer. 
Much of the information in the 
course has been available only 
through costly seminars. Now 
you can purchase this complete 
home study course for under 
$50.00. Send for free descriptive 
brochure now. 


LOGICAL. 


SERVICES INCORPORATED 


711 Stierlin Rd, Mountain View, 
CA 94043 (415) 965-8365 


microcomputers 


— Computers for People — 


IMSAI 8080 


At Special Introductory Prices 
(Prices Effective Until December 31, 1976 Only) 


1-8080 Kit 
1-8080 Kit with 22 Slot Mother 
• Add $9 each for shipping and handling 
* New York residents add Sales Tax 
* Send check or money order for full amount 
(Allow 3 weeks for personal checks.) 


WE TAKE MASTERCHARGE 
OR BANKAMERICARD 
FOR MAIL AND PHONE ORDERS 


For orders, information or special prices 
on all IMSAI products 


Call: (315) 637-6208 


Р.О. Box 71 * Fayetteville, М.Ү. 13066 


Ask for Our Special Price Sheet. 


Audio Design Electronics 


Presents A New Concept in 
Mini/Micro Computer 
Shops 


ae 


The Computer Emporium 


офа 


Authorized Dealers for 
IMSAI, S.W.T.P.Co, О.А.Е. 
Processor Technology, 
D.B.S. and many others. 
Come see our showroom 
and see the Difference. 
Support Service Sales 


The Computer Emporium 
487 Broadway 510-512 
New York, N.Y. 10013 

212-226-2038 


Attention: KIM-1 owners. 


For Sale: Assembler program com- 
patible with MOS Technology assem- 
bler. Uses KIM-1 cassette interface 
for storage of source and object 
programs. Also includes a text-editor 
program, and both run in 4K of 
memory. They are distributed on 
cassette in both source and object 
form, in case you wish to improve or 
modify them to suit your needs. 

Assembler/text-editor .. $19.50 ppd. 
Write for details on sale of your 
programs on a commission basis. 


Micro Software Specialists, Inc. 


2024 Washington St 
Commerce TX 75428. 


Photocopy or cut out this solicitation for 
information and send to: 


БНЕПЕДІНІЕ 


7338 Baltimore Ave., Suite 200 
College Park, Maryland 20740 


JOINT VENTURE 


GROUP OEM BUYS 


CHEAP, Inc. was set up to coordinate joint venture OEM 
Group Buys! Depending upon the total quantity of com- 
mitments received, you can expect to pay from 20% to 7096 of 
the retail sales price. Now you too can combine your orders 
with others throughout the country to purchase factory new 
electronic components at OEM rates, We will accept small 
Factory and Club commitments as well as individual 
commitments. 


Circle below the products you may ba interested in and 
estimate their quantity. After we receive this survey, we shall 
send, to you, more information, prices and delivery dates. 


Memories: 91L02 ——, 2102 «71202 = — — 

MicroP: | 280. — — ., 8080A____, 6800. — — 

P.C. Boards: Computer Grade double buffered optional parity 
memory boards compatible with the Altair 8800 on one 
edge and the Altair 680 on the opposite edge; 4:8: 16K - 

Floppy Disk Drives. è Disk Controlier 

Mag. Tape Огімеѕ ы Modems. 

TV Monitors — — — —., Oscillöscope m 

Sockets: 14 Pin 6 pin, —— ————. 
24 ріп, , 40ріп , Other. 

Software: Fortran. , PL/1 Subset 


Other: 
Other: 


EXTRA: We will consider purchasing general purpose Р.С. 
Boards and Kits, etc. Write us about what you may have to 
offer and its OEM prices. 


NOW! 


A Computer Store in 
New York, NY 


Offering the complete line 
of *Altair mainframes and 
peripherals as well as boards 
& boxes, tools & instru- 
ments, books & manuals, 
supplies & media. 


The Computer Store Inc. 
55 West 39th St 
New York, NY 10018 
212-221-1404 


*Altair is a registered tradename of 
MITS, Inc. 


For more information circle 


Build This 


Video Display Terminal 


| first became interested іп micro- 
processors about a year ago. After much 
thought, | decided to investigate this rapidly 
growing field. | did not have any particular 
goal in mind but | did want to learn how 
they work and what they can do. Therefore, 
| decided not to buy a kit but to build my 
own from scratch. | happened to select the 
Motorola processor for a number of reasons 
which | won’t consider here. After a few 
weeks, | had a small system up and running. 
| even managed to interface an old “Tele- 
Term" that | borrowed from the Mayo 
Clinic where | work. Now (1 thought) I had 
the cat by the tail (or the byte by the bit?). 


Alfred | Anderson 
721 15th Av SW 
Rochester MN 55901 


READ/ WRITE 


m 


RAM ADDRESS BUS 
IK X8 


PROGRAMMABLE 
MEMORY 


PROCESSOR ADDRESS BUS 


RAM DATA 


PROCESSOR DATA BUS 


zmao-«o 


VIDEO ADDRESS 


СО VIDEO ADDRESS | VIDEO 
GENERATOR 


VIDEO DATA 


mopm-umaAz-— 


PROCESSOR CONTROL BUS 


RF 
MODULATOR 


72-3002 
TRANSFORMER 


Figure 1: Video Terminal Systems Configuration. This block diagram shows 
how the terminal subsystem is organized as a display generator for the 
computer system, 
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It wasn’t long until | became impatient with 
the slowness of the TeleTerm, its loud 
clacking, and the reams of paper | was going 
through. What did | need? A video terminal, 
of course. There are a number of good kits 
on the market place. My impression was that 
they are either too expensive for my home- 
brew budget or they are Altair compatible. 
Now | needed Altair compatibility for my 
homebrew system like a write only memory. 
It would not have been a trivial task to 
interface any of the affordable video 
modules designed for the Altair to my 
homebuilt 6800 system. What could | do? 

The answer was in the June 1976 issue of 
BYTE. Мг Gantt’s article “Build a Television 
Display" /page 16] provided the basic infor- 
mation ! needed on television interfacing. | 
changed the circuit around a bit, added a 
few goodies, incorporated some memory, 
and wrote a few lines of software. | am now 
using a video terminal that you would like. 
The following paragraphs should outline 
everything you need to know to complete 
one of your own. 


Design Specifications 


For my purposes a video terminal had to 
have a number of features | deemed to be 
desirable. First, | wanted immediate access 
to any character on the screen without 
having to mess around moving little white 
boxes. This feature allows me, for example, 
to keep a real time clock display in the upper 
right hand corner of the screen. This video 
terminal uses a simple minded direct 
memory access technique enabling a com- 
plete screen update in the twinkling of an 
eye. | chose a screen configuration of 16 
lines by 32 characters per line. This limited 
amount of data didn't really concern me 
since 1 would also be using scrolling. This 


то 


YSTEM 
INTER- 
FACE 
1С51 
MM5320 
+5V 
1C64 тру; ІС64 — — — —— — | екен — 
740 „ 7404 [ m 
ШТІ: 
| VIDEO 
ойт 
NOTE: ALL RESISTOR VALUES ARE OHMS © Wes Ò 7 о T ©) 
| ay || 
| 89 ó9| 
[кез | 


Figure 2: Detail Schematic of the Video Generation Circuitry. This section of the design includes all timing logic and character 
generation logic. See table 1 for a complete parts list for figures 2 and 3, and see table 2 for the power wiring list. 
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BIDIRECTIONAL 
DATA BUS 
FROM PROCESSOR 


TERES 
mri 


DO] оргрзра 
+5V 
Уро» 
ШІ, = 
| > 
| > 
ура 
: L > 
TO VIDEO 
ENERATOR 
FROM ADDRESS 
PRO- SELECT 
CESS HEXADECIMAL 
ОСОО TO OFFF 
IC 13 (8178.0 ТО ADDRESS мов 
8797 ! D 
= 2 > 
Ber Zira ОА 
Г > ғ B ов 
DAR ос 
ем} 
ADDRESS DATE" IN 
o TPI6 
MATCH MEMORY ARRAY 
5 740 8 2ILO2-1 INTEGRATED CIRCUITS 
P alicas ІС24 IC 34 DATA 
1625 1С35 ойт 
Ic 26 IC 36 
1С 27 1637 
NOTE :X.7=ALL IC'S, PIN 7(TYP) 
26125 PIN I2, IC 26 (TYP) 
X3 RW 
A9 AB AT A6 А5 AS A3A2 
X2 X7X6X5 
l- PROCESSOR 
O* VIDEO 
[549 
[ 548 
>а 
[ 52 


A Ll 
lA 


ADORESS BUS 


FROM PROCESSOR FROM VIDEO 


GENERATOR 


Figure 3: Detail schematic of the system interface and memory for this video terminal design. In this diagram, the processor 
interface is at the top and left edge, and the video generator interface to figure 2 is at the right of the drawing. 
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allows the display of any 16 consecutive 
lines of the 32 lines kept in memory. To be 
fancy, | thought it desirable to have both 
white on black characters and the reverse 
(black on white) for highlighting. The termi- 
nal should use the standard power supplies | 
had available in my system (+5, +15, 
-15 М). Since | didn’t want to fool around 
modifying my television ! included an RF 
modulator to feed the signal to the TV 
antenna inputs. My entire system was built 
on Vector #3677 and 3682 DIP plugboards. 
Therefore, this video terminal should also fit 
on the same type of board. 

Finally, and most important, it had to be 
compatible with MY system. | should prob- 
ably add that this terminal can of course be 
adapted for any computer system. It is alot 
easier to interface Motorola systems to Intel 
systems than vice versa. 


Functional Implementation 


Figure 1 shows the relationship between 
various modules comprising this video termi- 
nal. The system incorporates a 1 K X 8 
programmable memory to refresh the screen. 
The contents of the first 512 bytes is 
constantly being accessed by the video 


display generator. The video output is 
routed through coax to an RF modulator 
adjusted, in my case, to channel 5. This is 
coupled to a nine inch (22.86 cm) GE black 
and white portable TV through a six foot 
length of coax and an impedance matching 
transformer. The interface section of the 
terminal is quite simple. Its sole purpose is 
to allow the processor to access the video 
memory whenever it desires. | felt that ап 
occasional high priority interruption to the 
display was preferable to slowing down the 
processor. After the system was built, ! 
discovered that no interference could be 
seen on the terminal when the processor was 
updating the display. 

This display interface was built on a 
standard 4/2" by 9%” (11.4 cm by 24.1 cm) 
Vector #3677 plugboard which I highly 
recommend. The board has two power buses 
etched on the reverse side. | have never 
experienced any problems with the power 
distribution while using these boards. The 
board was wire wrapped with all integrated 
circuits in sockets. Isolated discrete com- 
ponents were mounted with wire wrappable 
terminals. Analog subsystems were mounted 
on dual in line header plugs which, in turn, 
were mounted in wire wrapped integrated 


Listing 1: A Memory Test Program for the 6800. This program tests the user memory of the 
television interface. If an error is found, the program stores the parameters of the erroneous 
location in locations VALUE (the test pattern to be stored), RSLT (the garbled test pattern 
read from the bad location) and ADDR (the address of the bad location). The limits of the test 
are arbitrary, being set by the constants at STRTADR and ENDADR. An error condition is 
concluded by entry into an endless loop of one instruction in length, thus locking up the 
machine until reset by the programmer making the test. 


Addr Нех Code Labe! Op Operand Commentary 

0000 DE 22 MTST LDX STRTADR X ;= STRTADR [define starting address] ; 
0002 86 O0 LOOP1 LDAA #0 A :7 0 [define first test pattern] ; 

0004 A7 00 LOOP2 STAA ОХ GX- A [write test pattern] ; 

0006 01 NOP Let the memory circuits settle 

0007 01 NOP down a bit between accesses; 

0008 Е6 00 LDAB 0,Х B := @X [read test pattern back] ; 

000A 11 СВА Does test pattern read match original? 
0008 26 09 ВМЕ ERROR If not then quit with error; 

0000 4С INCA А ;= А + 1 {define next test pattern] ; 
000Е 4D TSTA Is A = 0? [have all patterns been used?] ; 
000Е 26 ЕЗ ВМЕ LOOP2 If not then continue cycle at current address; 
0011 08 INX X =X +1 [define next test address] ; 
0012 9C 24 CPX ENDADA 15 X = last address? 

0014 26 EC BNE LOOP1 If not then restart test loops; 

0016 297 1E ERROR STAA VALUE VALUE := A [indicate source value] ; 
0018 D7 1F STAB RSLT RSLT := B [indicate resulting value] ; 
001A DF 20 STX ADDR ADDR := X [indicate address of problem] ; 
001С 20 FE OOPSLOOP BRA OOPSLOOP Hang ир in endless loop until restart; 


Data Required By MTST: These locations are at absolute addresses in the first 
page of memory, and are referenced by direct addressing. If the program is re- 
located, the variables should remain in page zero. 


001Е 00 VALUE FCB 0 
001Е 00 RSLT FCB 0 
0020 00 00 ADDR FDB 0 
0022 00 00 STRTADR FDB 0 
0024 00 00 ENDADR FDB 0 


Error value; 

Error result; 

Error address; 

Starting address of test; 
Ending address of test; 
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Table 1: Video Terminal Parts List. This listing summarizes the parts 
identifications, sources of supply and approximate cost of this design as built 
by the author. The costs for most parts are typical. The only part for which it 
may be difficult to find alternate sources of supply is the Pixe-Verter, a brand 
name product, The names and addresses of the vendors used by the author 
are listed at the end of the table, 


Approximate 
Quan Type IC number Source Cost* 


Integrated Circuits, TTL 


circuit sockets. The radio frequency modula- 
tor was located off the board in a shielded 
metal box underneath the computer chassis. 
All video and radio frequency signals are 
routed through 72 ohm ЕС 59/0 coax 
cable. Needless to say, only good quality 
components were used in the construction 
of this system. Out of spec chips, in my 
opinion, are useful only for making tie tacs 
[and for stapling notes to bulletin boards]. 


Hardware Configuration 


Figure 2 is the schematic of the video 
processing subsystem. This circuitry is sub- 


1 7400 1С53 Јатеѕ 18 4 na А . 
2 7404 1C32, ІС64 James .32 stantially the same as the circuit designed іп 
2 7410 1C33, ІС42 James 40 the article by Mr Gantt. Several component 
2 7485 IC11, 1C23 James 1.78 his original 
2 7486 1С76, 1C77 James 78 values һауе been altered from his origina 
2 7490 1C31,1C44 James 1.38 design. 74123s were used to reduce the 
1 7492 IC52 James 82 : 
2 74123 1С43, 1С45 ‘lames 210 package count with excellent results. The 
3 74157 C14, IC15, IC16 James 3.90 dot counter clock is not derived from the 
! 24165 Icas James 1,10 crystal frequency. Instead, а one shot multi- 
ames . р . . . 
3 74193 1С47,1С54,1С55 James 4.30 vibrator is used to give variable character 
Ее width. This allows one to adjust the line 
Integrated Circuits, MOS width to the sweep time of the individual 
3 8T97B  1C12,1C13, 1C17 SD 4.47 TM being used. This frequency can be 
8 21L02-1 1C24, IC25, 1C26, 1C27, А d llow 64 charact line if 
1C34, 1C35, 1C36, 1C37 SD 12.95 Increase to allow cnaracters per line | 
1 2513N 1657 James 11.00 desired. Although they are clear, | prefer not 
1 MM5320 1С51 Nexus 4.95 to use a magnifying glass to read the data on 
Hardware the nine inch TV screen. Exclusive OR gates 
27 16 pin Wire Wrap Sockets '— James 1134 were inserted between the 2513 character 
9 14 pin Wire Wrap Sockets James 3.51 generator and the 74165 shift register to 
1 24 pin Wire Wrap Socket James 1.05 allow for reverse characters. Note that a 
1 14 pin DIP Plug James .64 . . А 
1 16 pin DIP Plug James 70 cursor is nothing more than a reverse space. 
221, wire Wrap Terminals, type 7-49 00: James 1.25 Only six data lines are required to specify a 
0 #30 ga Wire Wrap Wire (9.95/10007 Ace 3.50 particular 6 bit ASCII subset character code. 
Capacitors This allows the two remaining data lines to 
1 22 pF James 05 contain control information. If bit 7 is on 
2 47 pF James 10 (the most significant bit), the exclusive OR 
1 100 pF James 05 ; а 
1 10047 mE, Mylar "ames 42 gates act as inverters to produce a reverse 
1 .01 mF, Mylar James 12 character. If bit 7 is off, they act as buffers, 
31 i тр, ceramic bypass (3.75/50) James 2.33 passing logically true data for a standard 
2 100 mF, 16 volt, electrolytic James 728 character. Bit 6 is currently unused. This 
Resi could be used to enable a blinking gate to 
esistors make individual characters flash on and off. 
1 O; . H 
1 27 опт, % watt, 5% carbon James 5 Or it could be used to disable the character 
1 150 ohm James 05 generator and enable a handblown PROM 
2 330 ohm James 10 array which would allow a certain degree of 
onm ames n 1 HH 1 1 
3 1k "James 45 graphic text capability. The video combiner 
1 18 k (particular value unit dependent) James 05 
3 20 К, 10 Turn, Trimpots #43P203 James 4.05 
Semiconductors 
1 1N4742, 12 V Zener Diode James ‚29 
1М751А, 5 V Zener Diode James 25 Vendors’ Addresses 
1 2N3904, NPN GP Transistor James ‚25 
А SD Sales; РОВ 28810; Dallas TX 75228 
Miscell ; ; 28. 
все апеои$ Burstein-Applebee; 3199 Mercier St; Kansas City 
1 10 MHz Crystal # CY12A James 4.95 MO 64111. 
1 Vector #3677 Plugboard B-A 10.38 Nexus Trading; Box 3357; San Leandro CA 94578 
i Vector R644 Plugboard Receptacle B-A 4.32 ісе: i | ` 
1 Pixe-Verter, Model #PXV-2A ATV Rsh 8.50 Јагпез opm ronies; 1021 Howard St; San Carlos 
10' RG 59/U Coax Radio Shk 60 tos 
1 72 ohm to 300 ohm Transformer Radio Shk 2.95 ATV Research; 13th and Broadway; Dakota City 
2 RF Connectors Radio Shk .89 NE 68731. 
ACE Electronic Parts; 5400 Mitchelldale B-8; 
Approximate Total Cost $115.28 Houston TX 77092. 
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is different from that shown in Mr Gantt’s 
article. The 2N3904 transistor is controlled 
by the addition of the two inputs (com- 
posite sync and video) It provides the 
proper interface to the RF modulator. Note 
that nearly every integrated circuit is by- 
passed with a 0.1 mF ceramic capacitor. 
This insures a clean power supply line with 
little or no switching transient noise. | felt 
this to be especially important in view of the 
different nonrelated frequencies in the ter- 
minal. Notice the small circled numbers that 
are alongside of the discrete components in 
the crystal time base and video combiner 
systems. These refer to the pin locations on 
an IC plug which holds the components. 
Anyone familiar with interface boards 
will recognize the simplicity of the one 
shown in figure 3. The address lines on the 
left side of the schematic are from the 
processor's buffered address bus. The data 
lines at the top are to the bidirectional 8 bit 
data bus. The 10 address lines and eight data 
lines to the right side are interconnections to 
the video terminal controller. The high order 
address lines from the processor along with 
the 6800's VMA (Valid Memory Address) 
signal are decoded by the four bit magnitude 
comparators IC11 and ІС23. The memory 
address is set by the levels on the B side 
inputs of these 7485s. The schematic shows 
a setting for a memory address of hexa- 
decimal ОСОО to OF FF, 1C23 pin 6 toggles to 
a positive level whenever the high order 
address from the processor bus matches the 
preset address. Within nanoseconds the data 
selectors (74157s, IC14, IC15, IC16) switch 
control of the memory address lines from 
the display generator to the processor bus. 
Half a microsecond later, with the address 
firmly established on the memory chips, the 
phase 2 clock goes high enabling the write 
line (if writing data) or the output buffers (if 
reading data). While the memory reference is 
being made by the processor, the terminal 
hardware may attempt to load a character. 
The character it gets is not necessarily the 
one at the address it wants but the character 
that the processor is addressing. This would 
seem to cause an improper character to be 
displayed. However, since this contention 
occurs so infrequently and the refresh is so 
rapid, no visible interference is seen on the 
TV screen in a typical situation. The pro- 
grammable memories are of the 21L02-1 
variety. Except for the data in and data out 
connections, the memory integrated circuits 
are all wired in parallel. They are perma- 
nently enabled by tying their chip select 
lines to ground. This hardware is about as 
simple as can be expected. It should not 
present any problems to anyone with any 


experience in assembly of electronics. 
Photos 1 to 17 show waveforms at selected 
test points identified on the schematics. 
These photos illustrate typical waveforms of 
my completed display board, taken from a 
Tektronix 455 oscilloscope. 


Software Support 


The primary disadvantage of this system 
as a terminal is the lack of a local mode like 
a hard copy printer or traditional display 
terminal. All data to be written on the 
screen must pass through the processor. This 
is not a serious disadvantage unless one 
desires a stand alone toy TV typewriter. You 
may choose to develop your own software 
(you have to if your processor is not a 
6800!) or, if you are running a 6800 
system, you might like to give mine a try. 

This software is a collection of com- 
pletely relocatable subroutines (that is, the 
following package can reside anyplace in 
memory without changing any subroutine 
addresses). There are five entry points of 
interest. They allow your programs to: 


Table 2: Power Wiring List. This table lists 
each integrated circuit of this project and its 
power supply wiring pins, The rest of the 
wiring is done according to the schematics of 
figures 2 and 3. 


No Device +5 V —5V -12У GND 
IC11 7485 16 

IC12 8T97 16 

IC13 8T97 16 

IC14 74157 16 

ІСІБ 74157 16 

IC16 74157 16 

ІСІ? 8T97 16 

IC21 A1 

IC23 7485 16 


ІС24 21102-1 10 
ІС25 21102-1 10 
ІС26 21102-1 10 
ІС27 21102-1 10 


8 
8 
8 
8 
8 
8 
8 
8 
9 
9 
9 
9 
ІС31 7490 5 10 
ІС32 7404 14 7 
IC33 7410 14 7 
1C34 21102-1 10 9 
(C35 21102-1 10 9 
tC36 21L02-1 10 9 
ІС37 21102-1 10 9 
IC42 7410 14 7 
ІС43 74123 16 8 
ІС44 7490 5 10 
ІС45 74123 16 8 
IC46 74192 16 8 
ІС47 74193 16 8 
ІС5І ММ5320 8 1 
ІС52 7492 5 10 
IC53 7400 14 7 
ІС54 74193 16 8 
ІС55 74193 16 8 
IC57 2513 24 12 1 10 
ІС61 А2 118413 8 
ІС64 7404 14 7 
ІС65 74165 16 8 
ІС76 7486 14 7 
IC77 7486 14 7 


Waveform Photographs 


The oscilloscope photos, 1 to 17, are included for 
trouble shooting purposes, These were taken ona 
Tektronix 455 oscilloscope using a 10X probe. 
Unless otherwise noted, the vertical sensitivity is 1 
volt per division. The horizontal sweep speed and 
test point location are shown in the caption of 
each photograph, The ground reference line is one 
division below the center line in each photograph. 


Photo 12: Test point 12, 
pin 4 of IC64, 200 us per 


Photo 1: Test point 1, pin 
1 of ІСЗІ, 50 ns per 


division. 


Photo 2: Test point 2, pin 1 of 1C43, 
200 ns per division. 


Photo 3: Test point 3, pin 4 of 1C43, 
200 ns per division, 


Photo 4: Test point 4, pin 13 of 1С45, 
20 us per division. 


Photo 5: Test point 5, pin 12 of 1C44, 
5 ms per division. 


Photo 6: Test point 6, pin 1 of IC44, 
2 ms per division. 


Photo 7: Test point 7, pin 5 of IC43, 
2 ms per division. 


Photo 8: Test point 8, pin 12 of IC45, 
50 ns per division. 


Photo 9: Test point 9, pin 6 of ІС42, 
100 ns per division. 
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Photo 10: Test point 10, pin 3 of 
1053, 10 us per division. 


ге je 
Photo 11: Test point 11, pin 2 of 
1C55, 200 us per division. 
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division. 


Photo 13: Test point 13, pin 12 of 
ІС42, 500 us per division. 
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Photo 14: Test point 14, video output, 
0.5 V per division vertically, 2 ms per 
division horizontally. 
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Photo 15: Test point 15, video output, 
0.5 V per division vertically, 100 us 
per division horizontally, 


Photo 16: Test point 16, pin 6 of 
1C23, 1 us per division, 


Photo 17: Test point 17, pin 6 of 
[C33, 500 ns per division. 
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Photo 18: Video Terminal Board, Component Side. This photograph shows the physical layout 
of the board as constructed by the author. The processor connections to and from the terminal 
are made by the plug on the left hand side of the photograph. Eight 27L02-1 memory 
integrated circuits are used for the screen's local memory. The three pots at the bottom center 
are used (L to R) to control left hand margin, character width, and top of page margin. The 
video amplifier is contained in the DIP plug with components, in the lower right hand corner. 
Bypass capacitors are sprinkled quite liberally throughout the board. 


START JSR ESCRN 
LDX «TITLE 


Erase the entire screen; 
X := address of title string; 


n 1 JSR VLINE Write title at top of screen; 
1. Display a ШЕ” line of ASCII text. LDX #PROMPT X := address of prompting message; 
2. Scroll all lines up by one. JSR VLINE Write prompting message on next line; 


LDAA #$A0 A:=' ' + 80 [add hex 80 to blank giving inverted blank] ; 


3. Erase one character line. JSR VCHAR Write cursor at location of next input; 
4, Add one new character to the display. . 
5. Erase the entire screen. TITLE FCC ‘GENIE OPERATING SYSTEM’ тін 
ЕСВ 4 Ше string; 
PROMPT ECC WHAT IS YOUR DESIRE, MASTER? prompting string: 


The preambles for each subroutine should 
adequately explain the calling sequence and 
conventions used. These subroutines assume 
that six words are available in the first page 
(256) of memory (hexadecimal address 0 to 


Or if you really have to have a routine 
which will allow you to type data on your 
keyboard and look at it on the screen: 


LOCAL JSR ESCRN Start by clearing the screen; 
FF). These words are used to take advan tage LOOP JSR vi Use normal input routine to define character in A; 
Я : JSR VCHAR ТІ fer i h ffer; 
of Motorola's direct addressing feature. To CMPA #$04 Is it end of text? CE ыы ына, 
display a character in a preset location on ВМЕЗ КООР Ifinot:then continue local LOOP; 


the screen, initialize the words CHAR and 
LINE to the desired location, load the 6 bit 
ASCII character into the A accumulator and 
branch to the VCHAR subroutine. 

The complete relocatable software is in- 


Return to monitor 


Note that scrolling is done automatically 
for you after you write the 32nd character 


cluded as listing 2 with this article. A 
symbolic example is given here to show the 
use of these routines. Suppose that you 
desire to erase the screen, display a title, a 
prompting message, and place a cursor at the 
next character location. This can be accom- 
plished by the following code: 


on the 16th line. 


Construction 


Before you can begin building this termi- 
nal, you first must obtain the necessary 
components. Refer to the component list in 
table 1. | have listed the vendors from which 


113 


— 


- EMIT шама хам ш 
4 a E - 24 - ] <= — 


ке 
E 


wyrys ооч ^ 


>e s> : 
Lo» 


Photo 19: Video Terminal Board, Wiring Side. This photograph shows the 


wire wrapped construction of the circuit's prototype. All integrated circuit | purchased the parts. | selected these people 
locations were labelled with masking tape containing device location and because | knew | would get quality com- 
device type. All integrated circuit power connections were soldered to the ponents at reasonable prices in a short time. 


etched power supply buses which are part of the Vector plugboard used for The prices listed are included as a guide. 
the circuit, The orientation of pin 1 is uniformly the upper left corner of the Check the advertisements in this issue to see 
integrated circuit, as documented by the typical pinout map shown pasted to if they have changed. 

the upper right side of the board. The first step in building this (or any) 
board is to determine exactly where the 
various components will be located. See 
photo 18, photo 19 and figure 4 for the 
layout | used. Then install all of your bypass 
capacitors, This is easy to do at this stage. 
Solder them directly to the etched lands on 
the reverse of the Vector board between the 
known locations of the wire wrap sockets. 
Next (and this is a trick that will really 
reduce the wire wrap errors) cut masking 
tape into sections a little smaller than 
the size of the integrated circuit top. Write 
on the masking tape the integrated circuit 
number and the TTL suffix. For example, 


Photo 20: A Detail of the Computer System, 
This 6800 microcomputer currently consists 
of four cards: ап ІО саға, a processor card, а 
4K byte programmable memory card, and 
the video terminal card described in this 
article, One spare location at the left is 
awaiting a 16K dynamic programmable 
memory card which is under development. 
Тһе ribbon connectors in the lower right 
hand corner are used to interface a control 
panel, Each board is supplied from a sepa- 
rate 5 V regulator which is mounted on the 
chassis for superior heat sinking capability. 
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"[C45-123" identifies the fifth integrated 
circuit in the fourth column as a 74123. Pin 
1 is always in the upper left hand corner 
looking from the wrap side of the board. 
Place the label on the wrap side of the board 
where the socket will go. Next, put a dab of 
cement on the bottom of the integrated 
circuit socket and insert it on the board. (I 
used “DUCO” cement. Epoxy or hot melt 
glue can be used, but are nearly impossible 
to remove once set.) Remember that 16 pin 
sockets are a little longer than the 14 pin 
variety and you'll be OK. Refer to figure 4 
for the configuration | used. After the glue 
has set, wire the power supply lines to the 
wire wrap sockets. To do this, wrap half a 
dozen turns around a power pin and solder 
the other end to the nearest power bus. 
Don’t ‘‘daisy chain” a bunch of circuits 
together with one attachment to the power 
bus. The 30 gauge wire can’t adequately 
handle the required switching current for 
more than a few chips. Insert the wire wrap 
terminals where the discrete components 
will be placed. Many of these can be 
soldered directly to the power planes. Other- 
wise, they have enough friction to prevent 
them from falling out before they are 
wrapped. It’s time for one more trick to 
reduce the number of wire wrap errors. Get 
a Xerox copy of the schematics (figures 2 
and 3). /ВҮТЕ encourages this and gives full 
permission for such private use duplication. | 
Each time you complete a connection, use a 
felt tipped pen to draw over the line on the 
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Figure 4: Video Terminal Component Layout. This reduced scale drawing 
shows the relative position of the parts of the video terminal design as 
constructed by the author. See photo 18 for a pictorial version of this layout, 
and see photo 19 for the reverse side of the author's card as wired for his 
system. 


Listing 2: Complete Video Support Software for a Motorola 6800 Processor. 
This package consists of self relocating routines to perform display utility 
functions. Self relocation is accomplished by exclusively employing branch 
instructions (relative addressing) for program control within the package, and 
using the stack as a temporary where necessary. Control variables are assumed 
to be in low memory. 


The following allocations are located in page 0 of memory, so that the video support 
software can take advantage of the Motorola 6800 direct addressing mode. Relocation 
of these variables should be confined to page 0, in which case the address constants used 
for the direct addressing references would be altered to reflect new locations. The main 
text of the subroutines themselves is completely position independent, which means re- 
location can be accomplished simply by louding the program code at a different point in 
memory address space und calculating new addresses for the "external references" sum- 
marized in a table at the end of this listing. 


Abs 

Addr Нех Code Label Op Operand Commentary 

0020 00 CHAR RMB Character position, O (left) то 31 (right): 
0021 00 LINE RMB Line number, O (top) to 15 (bottom); 

0022 00 O0 CHPSN RDB Memory address pointer to character; 

0023 CHPSNL  EQU CHPSN+1 Low order byte of memory address pointer; 
0024 00 00 SAVEX RDB Index register save area; 


fhe following equate ussigns a value to the address of the video display memory for 
the purposes of symbolic reference within this listing. The addresses of the displayed 
portion of memory in the prototype of this design are ОСОО to OF FF in hexadecimal. 


VIDEO EQU ч«50С00 


Listing 2 is continued on the next three pages... 
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Listing 2, continued: 


VLINE — This subroutine displays a new fine of text on the screen. On entry 
to VLINE, the index register X has the address of the start of the ASCII text 
string to be.displayed. The string is terminated using an ASCII EOT character, 
hexadecimal 04, as the last character. 


Rel 

Addr Нех Code Label Op Operand Commentary 

0000 VLINE EQU * Entry point, line display routine: 

0000 36 PSHA Save A on stack; 

0001 7Е 00 20 СІН CHAR CHAR := 0 [perform carriage return] ; 
0004 7C 00 21 INC LINE LINE := LINE + 1 [perform line feed] ; 
0007 A6 00 VLP LDAA О,Х А := @X [move next character to А]; 
0009 81 04 CMPA 4 Is it end of text? 

0008 27 05 BEQ VLDNE If so then return to caller; 

0000 8D 15 BSR VCHAR CALL VCHAR [display the character] ; 
O00F 08 INX X := X * 1 [point to next character] ; 
0010 20 F5 BRA VLP Reiterate until done; 

0012 32 VLDNE PULA Restore A from stack; 

0013 39 RTS Return to caller; 


ESCRN — This subroutine is used to erase the entire screen, It has no input 
parameters. 


Rel 

Addr Нех Code Label Op Operand Commentary 

0014 ESCRN EQU Ы Entry point, erase screen routine; 

0014 36 Р5НА Save А on stack; 

0015 86 OF LDAA #15 A := 15 [set number of lines to erase} ; 
0017 8D 68 ESLOP BSR ELINE CALL ELINE [erase one line] ; 

0019 4А DECA А := А — 1 [decrement line count in А]; 
0014 2C FB BGE ESLOP if A >= 0 then continue the loop; 

001С  7F O0 21 CLR LINE LINE := 0 [move cursor to top of screen] : 
001Е  7F OO 20 CLR CHAR CHAR := 0 [move cursor to left of line]; 
0022 32 PULA Restore A from stack; 

0023 39 RTS Return to caller; 


VCHAR — This subroutine displays one character on the screen. On entry, 
the А accumulator should contain the ASCII character code to be displayed. 
VCHAR updates the control variables LINE and CHAR which determine 
screen location; VCHAR ignores all ASCII control codes except a carriage 
return or line feed. 


Re! 

Addr Нех Code Label Op Operand Commentary 

0024 VCHAR EOU * Entry point of character display routine; 
0024 81 OD СМРА 2$0D 15 character a carriage return? 

0026 27 09 BEQ VCR 1f so then go juggle CHAR pointer; 

0028 81 ОА СМРА я%0А Is character a line feed? 

002A 27 09 BEQ VLF If so then go juggle LINE pointers; 

002C 81 20 CMPA ='' Check for ASCII control character; 

002Е 2С 09 ВСЕ уок |+ so then go transfer valid ASCH; 

0030 39 RTS Else return with no action; 

0031 7F 00 20 VCR CLR CHAR CHAR := 0 [perform carriage return] ; 

0034 39 RTS Return to caller; 

0035 7С 00 21 VLF INC LINE LINE := LINE + 1 [perform line feed] ; 
0038 38 RTS Return to caller; 

0039 37 VOK PSHB Save B on stack; 

003A 36 PSHA Save A on stack; 

0038 06 20 LDAB CHAR В := CHAR; 

0030 СІ 1F СМРВ #31 15 it still on the same line? 

ООЗЕ 2F 06 BLE VCOK If so then go test tine [do not pass CRLF) ; 
0041 7F 00 20 CLR CHAR CHAR := 0 [pertorm carriage return] ; 
0044 7C 00 21! INC LINE LINE := LINE + 1 [perform line feed]; 
0047 96 21 VCOK LDAA LINE Is LINE on 

0049 80 OF SUBA #15 the screen? 

004В 2F OB BLE VLOK Vf so then go to display [do not pass home] ; 
0040 8D 1D VLNOK BSR VSCROL CALL VSCROL [move all lines up опе); 
QO4F 4A DECA A:=A—1 [decrement scrolling count] ; 
0050 26 FB BNE VLNOK if A >= 0 then loop [until line on screen] ; 
0052 86 OF LDAA #15 A := 15 [position cursor at bottom line] ; 
0054 97 21 STAA LINE 

0056 8D 2C BSR ELINE CALL ELINE [erase the bottom linel ; 
0058 96 21 VLOK LDAA LINE Set up LINE parameter for GCHAR call; 
005А D6 20 LDAB CHAR Set up CHAR parameter for GCHAR call; 
005C 8D ЗЕ BSR GCHAR CALL GCHAR [to calculate CHPSN pointer] ; 
005E DF 24 STX SAVEX Save index register value; 

0060 DE 22 LDX CHPSN X := CHPSN [point to current character address] ; 
0062 32 PULA A :7 current character; 

0063 A7 00 STAA 0,X GX := А [store current character in memory @ X] ; 
0065 7C 00 20 INC CHAR CHAR := CHAR + 1 [set pointer for next write] ; 
0068 DE 24 LDX SAVEX restore old index register value; 

006A 33 PULB restore B from stack; 

006B 39 RTS return to caller; 
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copy. You are done when all of the lines are 
marked over. Remember to mark the power 
supply lines too. | should probably insist 
that you recheck all of your connections 
after you're done... however, | don't and | 
don't expect that you will either. It is easier 
to verify your connections as you make 
them and fix the ones you missed during 
checkout. 

Now that your board is wrapped it's time 
to stuff all the circuits in and turn the power 
on, right? WRONG, Go slowly and test your 
work. You may end up saving some expen- 
sive circuits. First, measure your +5 V power 
supply. If it is not within 0.25 V of 5 V, find 
out why. Too low a voltage impedes per- 
formance. Too high and your chip life is 
reduced. Next, install the interface chips 
(IC11, ІСІ2, IC13, IC14, IC15, IC16, IC17, 
ІС23 and 1C33). Put a scope on pin 1 of 
IC16 and verify a positive pulse each time 
you address this memory space. The address 
of the memory space is determined by the B 
side inputs to the 7485s. This test can be 
done by a front panel or a software loader. 
This select pulse should be about 1.0 us in 
duration if you are running with a 1 MHz 
clock. Verify the address inputs at the 
programmable memory socket locations to 
make sure the 74157s are switching cor- 
rectly, Look at IC33 pin 3 and see a 500 ns 
negative pulse (normally high, goes low for 
about 500 ns, then high again) when you are 
writing to the programmable memory. 
Verify that there is no pulse when reading. 
Check for the reverse at IC33 pin 6. Expect 
a negative pulse when reading and just a high 
level when writing. Turn the power off and 
insert the eight 21L02-1 memory circuits. 
Each time a circuit is inserted, look to make 
sure all the pins are in the socket and not 
bent over. Power up again and run your 
memory test program. This verifies that your 
system can access this memory and that the 
integrated circuits are all good. An example 
of a simple memory test program called 
MTST is included in this article as listing 1. 

When you are sure that the processor is 
interfaced to memory correctly, insert C32, 
(C31, and IC43. Mount the DIP plug with 
the oscillator components in the (C21 
socket. Look at IC31 pin 1 on your scope 
and check for a 10 MHz "square" wave. See 
photo 1 for an example. Photo 2 shows the 
2 MHz wave at [C43 pin 1. If all is well so 
far, put your probe on ІСАЗ pin 4. This 
should be pretty close to a 2 MHz square 
wave. Adjust the timing resistor, if neces- 
sary, to obtain a 5096 duty cycle. This 
doesn't have to be exact but the 5320 is 
happier with a square wave. Measure pin 1 of 
ІС51 and verify a —12 V (+5%) DC voltage. 
With power off, insert this magical inte- 


grated circuit into its socket. This 5320 
generates all sorts of good signals and saves a 
lot of board space. With power on (and pin 1 
still at a clean -12 М), scope pins 11, 12, 14, 
15, and 16. They will be switching between 
*4.5 and —11 V. Don't be alarmed by the 
negative output voltage. They will pop up to 
ground when a TTL load is hung on them. 
With power off again, insert 1С45, ІС46, 
1C47, ІС64, 1C44, and ІС42. Adjust the Line 
Delay pot for a 20 us positive pulse at IC55 
pin 14. This adjusts the left hand margin on 
the TV display. It will be trimmed to a final 
value at a later time. Adjust the Top of Page 
pot for a 3 ms positive pulse at IC44 pin 14 
(this will also be trimmed later). Verify 
pulses at 1C57 pins 14, 15, and 16. Set the 
Character Width pot to midrange (about 
6.25 MHz at 1С32 pin 12) Refer to the 
waveform photographs if problems are en- 
countered, Insert everything else except for 
the character generator (1C57). Check that 
the address lines are toggling and that data is 
being presented to the character generator 
on pins 17 through 22. IC65 pin 9 should be 
switching erratically. Verify the power 
supply connections to ІС57, The +5, —5, 
and —12 V connections should be within 5% 
and should be c/ean, that is, without more 
than 100 mV of noise. 

Turn the power off and remove the 2513 
from its protective packing. This is the last 
device to be added to the board. 1t is also 
the most expensive circuit so don't blow it. 
With power on, recheck the supplies and the 
outputs from this circuit. 

Connect the video output from this ter- 
minal module to the video input of an RF 
modulator. | obtained excellent results using 
a Pixe-Verter. The RF output is transmitted 
by coax to a 72 to 300 ohm transformer. 
Disconnect the antenna from the back of 
your TV and attach the leads from this 
transformer. Tune to the channel you 
selected when building the Pixe-Verter with 
the TV's fine tuning set to midrange. With 
power on adjust the tuning capacitor on the 
Pixe-Verter for some sort of display on the 
TV. It will look ridiculous at first. You'll 
have to readjust the horizontal and vertical 
hold controls оп your TV for a stable 
display. Trim the three pots for a pleasing 
display on the TV screen. Then you can go 
to town using the display. 

The results of my project are shown in 
photos 20 and 21. 


Trouble Shooting 


Fortunately, this version of a video termi- 
nal worked the first time it was tried. This 
means | don't have any suggestions for 
locating failures based on experience. If you 
run into trouble, compare your waveforms 


Listing 2, continued: 


VSCROL — This subroutine moves all lines on the display up by one position. 
No input parameters are necessary. 


Rel 

Addr Нех Code Label Op Operand Commentary 

006С VSCROL EQU * Entry point of scrolling subroutine; 

006С 36 PSHA Save A on stack; 

0060 DF 24 STX SAVEX Save index register value; 

006Е СЕ OC 00 LDX #VIDEO Load pointer for start of move; 

0072 A6 20 VSCRL LDAA 32,X Fetch corresponding character, next line; 

0074 A700 STAA 0,х Then store it in the current line; 

0076 08 INX Х:= X + 1 [point to the next character] ; 

0077 ВС OF E1 CPX #(VIDEO+32*(32—1)+1) [calculated start of the last line in 
a 1024 byte buffer] ; 

007A 26 FE BNE VSCRL if not at end of buffer, then repeat loop; 

007C 86 OF LDAA #15 line parameter of erase function; 

007Е DE 24 LOX SAVEX restore index register 

0080 8D 02 BSR ELINE CALL ELINE [to erase bottom line] ; 

0082 32 PULA Restore A from stack; 

0083 39 RTS Return to caller; 


ELINE — This subroutine is used to erase one line from the display. The line 
number is specified by the value in accumulator A upon entry. 


el 


Addr Нех Code Label Op Operand Commentary 

0084 ELINE EQU * Entry point of line erase routine; 

0084 37 PSHB Save B on stack; 

0085 36 PSHA Save A on stack; 

0086 5F CLRB В := 0 [set local character position to zero] ; 
0087 8013 BSR GCHAR CALL GCHAR [calculate character address] ; 
0089 ОЕ 24 STX SAVEX Save index register; 

0088 DE 22 LDX CHPSN X := CHPSN [get calculated character address] ; 
0080 C6 20 LDAB #32 в 2 [the number of characters in a line] ; 


008Ғ 86 20 LDAA # А := *' [erase means put a blank in each pos.] ; 
0091 A7 00 ELLOP STAA 0,X @X := A [move the blank to current location] ; 
0093 08 INX X := X +1 [point to next location] ; 

0094 5A DECB B := B — 1 [decrement loop counter) ; 

0095 26 FA BNE ELLOP If count remains then reiterate; 

0097 DE 24 LDX SAVEX Restore index register; 

0099 32 PULA Restore A from stack; 

009A 33 PULB Restore 8 from stack; 

0098 39 RTS Return to caller; 


GCHAR — This subroutine calculates the memory address of a character 
specified by the current line number, LINE, and the current character 
position, CHAR. The formula is: 
CHPSN := 32* A + B + BASEADDR ; 

Where A is the line number, passed in accumulator A, B is the character 
position value, passed in accumulator B, and BASEADDR is a constant giving 
the first address in the character display area of memory. The value of 
BASEADDR in the author's system is hexadecimal 0СОО, Since the low order 
offset is zero, this constant is only added into the high order at location 
00С0 of this listing. 


Rel 

Addr Нех Code Label Op Operand Commentary 

009C GCHAR EQU Ы Entry point of the address calculator: 
009C 36 Р5НА Save А on stack; 

0090 37 PSHB Save B on stack; 

009Е БЕ CLRB Clear the character 

009Р 07 22 STAB CHPSN address variable 

00A1 07 23 STAB CHPSNL Prior to calculation; 

00АЗ 4А GLOP DECA A := A — 1 [decrement line count}; 
00A4 20 ОА BLT GCDS If A = О then multiplication is done; 
OOAG CB 20 ADDB #32 A := А + 32 [multiply is repeated addition] ; 
00А8 24 ҒӘ всс GLOP If no carry then continue inner loop; 
ООАА 7С 00 22 INC CHPSN Else increment most significant byte, 
OOAD OC CLC clear the carry flag, 

ООАЕ 20 F3 BRA GLOP and then return to inner loop; 

0080 07 23 GCDS STAB CHPSNL CHPSN+1 ;= A [save the low order byte] ; 
00B2 33 PULB Restore the displacement in line from B; 
0083 17 ТВА A := B [put it in А for calculation] ; 

0084 9B 23 ADDA CHPSNL A := А + CHPSNL [add low order bytes] ; 
0086 97 23 STAA CHPSNL CHPSNL := A [and save result in pointer] ; 
0088 24 04 BCC GDONE If no carry, then calculation is completed; 
OOBA 7С 00 24 INC CHPSN Else propagate carry to high order byte, 
оово ос CLC and clear carry; 

ООВЕ 96 22 GDONE LDAA CHPSN А := CHPSN [fetch high order byte] ; 
оосо 8B OC ADDA #H(VIDEO) A:= A *high order of VIDEO address; 
00С2 97 22 STAA CHPSN CHPSN := A [save final high order byte] ; 
00с4 32 PULA Restore A; 

00С5 39 RTS Return to caller; 
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Listing 2, continued: 


Notation conventions: 


RMB = "reserve memory byte" with or without label, uninitialized, 
ROB = "reserve double byte” with or without label, uninitialized. 
EQU = "equate''. Assign an address value to a label. 

# ж“ indicator for immediate addressing on Motorola 6800. 
$ппп = hexadecimal value nnn. 

nnn 7 decimal value nnn. 

* = the current location counter as in an assembly. 

"xXx 7 notation for ASCII character X. 


H(VIDEO) = notation for high order byte of address VIDEO. 
ex 7 data at location X (used in commentary). 


External Symbol Table: 


with those shown in the photos 1 to 17. The 
most likely cause of problems are defective 
integrated circuits and incorrect wiring. 


Future Additions 


If you want to display more characters on 
the TV screen, try disconnecting the wire 
from IC55 ріп 2 to ІС64 ріп 11. Replace 
with a wire from 1С55 pin 6 to IC64 pin 11). 
Wire 1С55 pin 2 to the 9th address bit at 
IC14 pin 2. Readjust the Character Width 
pot to squeeze all those characters on a 
single line. The software will have to be 
adjusted to handle the new memory con- 
figuration of 16 by 64. 

Like to try graphic text? Functionally 


The following symbols and their relative addresses are the entry points to the video display replace the 2513 with your own PROM. Bit 
support software. To calculate the absolute addresses needed to reference these entries, add the : ; 
f с 
starting address at which you load the package to each of these offsets, giving the absolute 6 could be used to perform this selection 


address to reference in a jump to subroutine instruction. 


electronically. This PROM could be used to 
define various line segments within a charac- 


Relative Address Label Operation ter field depending upon the 6 (or 7) bit 
0000 VLINE Line display code supplied. 
0014 ESCRN Erase screen { { { 
2054 VCHAR Display one character The very nicest thing about a homebuilt 
006C VSCROL Scroll up one line project is that after it is working, you’re not 
0084 ELINE Erase one line А Wu ipl А 
009C GCHAR Calculate address given line, position afraid to modify it: Happy Wrapping. m 


Photo 21: A Microcomputer Development Workshop? The processor is off in the left hand corner of the table, with a cassette 
tape recorder to its right. A keyboard with ASCII encoding is connected to the IO card for control of the processor. The video 
display's television set output is to the left of the oscilloscope at the right side of the picture. The parts cabinets, wire wrap gun, 


soda pop and ash tray were essential to the development of this system, 


We took everything we learned from selling 4Kx8 RAM boards for 

the past year, added some of this year's circuit tricks, and 

came up with ECONORAM--- a memory board that is even more re- 

markable due to its low price. We've engineered this with the 

user in mind, giving you several benefits: 

* 3 regulators to share power load, plus optimized thermal de- 
sign, means a cooler running microcomputer 

* Typlcal current consumption of under 750 ma gives your power 
supply a break 

* Fast --- Zero wait states 

* All TTL support ICs are latest Low Power Schottky types 

* For reliable and unambiguous data transfer, all addresses, 
data lines, and outputs are buffered for minimum loading and 
maximum output capability 

* Power-on clear included 


$99.95 


All these features are packed оп to an Altair-sized, industrial 
quality double-sided PC board, with sockets for all! ICs, 7 tan- 
talum capacitors for power supply decoupling, and plenty of by- 
pass capacitors---39 of them, in fact, as well as a logic print 
and instructions.  ASSEMBLED/TESTED UNITS ALSO AVAILABLE FOR А 
SURCHARGE; write for quotations and specify quantity. 

LIII PTOL IE ППТ Ir JI I | 


Our popular ECONORAM 4K x8 RAM board is now uma 


\ +2 185 POST 
ssemblec 


gooNORAM 


assembled, tested, and warranteed for one year. Plug 
it in to your Altair or IMSAI and enjoy the same per- 
formance that has made the kit such a success---guar- 
anteed zero wait states and current drain of 750 mA 
or less; on board regulation, easy address selection, 
and lots more. 


ПИЦИ 
GOLD-PLATED 3 LEVEL WIRE WRAPPING 

POSTS. IDEAL FOR MATING WITH 

ALTAIR/IMSAI PERIPHERALS: 

GIVES A SNUG FIT 

FOR YOUR PC 


IMSAI/ALTAIR EX- 
TENDER BOARD KIT 


--BUILT IN LOGIC PROBE 

--ALTAIR/IMSAI COMPATIBLE $25.00 

--ALLOWS YOU TO TROUBLESHOOT AND WORK ON 
BOARDS OUTSIDE OF THE SYSTEM. 
TAKING MEASUREMENTS ; 
BOARD EASY. 


100 
PIN 
EDGE 
CONNECTOR 
55 EACH--$22 FOR 5 


ШОШО 


Ц/61 


IDEAL FOR 
MAKES PROBING THE 


ПИ ОООО 


[EIGHT POLE 
SINGLE 
TRROW 


TOGGLE 
aoe ACTION 
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AKXS NAKED RAM к VECTOR! 


oo This is one of the neatest Altair 
“ accessories we've seen. |t accepts 

virtually any size |C package, has a 

power and ground plane on opposite 
sides of the board for extra capacitance. 
Room for 4 regulators, 1 heat sink provid- 
ed with board. By the way, the sockets 
are shown only for illustration, but they 
get the point across that you can stuff a 
lot of ICs on here--- implement your own 
memory boards, 1/0 boards, etc. 


This 4K by 8 memory board has 
no frills, just storage. De- 
signed for compatibility with 
JOLT systems, this board is 
also ideal for other micro- 
computers using bi-direction- 
al buss systems. Same size 
as JOLT memory card, plus 10- 
power operation (750 ma) to 
keep you on good terms with 
your power supply. 


1Ғ you don't need the onboard 
regulation or address / data 
buffers of our “Bigger Bro- 
ther" 4K board, 
the way to go. 


Sockets included for all ICs. 


then this is 


* anat 


UNIVERSAL PROTOTYPE 
BOARD » ® ® $19.95 


$179.95 


ALTAIR 8800/1MSAI PLUG- IN COMPATIBLE. This is a 4K 
by 8 EROM board...the ideal place for putting soft- 
ware, be it assembler, editor, or any custom set of 
routines. Additionally, this board may expand to 
BKx8 by simply adding more sockets and EROMs ; also 
available is a 2Kx8 version if you don't need a 


full 4K. LOW POWER: 8K board requires XA @ 5V, & 
150 ma @ -12V. Buffered addresses for lightest 
loading, buffered outputs for maximum drive. Kit 


includes sockets, double-sided quality PC board, 
on board reguletors, logic print, and instructions, 
Program it yourself, or have us do the programing. 


8K X8 BOARD $269,95 2K X8 BOARD $135.00 


8080 Software Bourd $189.95 


We took our ECONOROM board kit, but instead of including 
blank ЕКОМ5, these аге progranmed with assembler, editor, 5 
monitor routines for the 8080. This is a valuable first step 
if you're trying to get away from machine language programing. 
There's not really enough room here to fully describe all the 
functions of the software...but if you send us $2.95 (refund- 
able with order), we'll send you our software packet that in- 
cludes instructions listing, schematic, and assembly data. 
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7415 TTL 


00 $0.36 132 $1.50 175 $1.35 
01 0.36 32 0:38 138 1.38 221 1.38 
02 0.36 37 0.53 139 1.38 240 1.88 
04 0.42 38 0.53 155 1.38 257 1.25 
08 0.38 42 1.25 157 1.25 258 1.38 
10 0.36 74 0.56 160, 161, 273 2.25 
11 0.38 75 0.85 162, 163- 283 1.20 
20 0.36 109 0.60 81,85 еа. 367 1.00 
21 0.38 124 2.50 168 1.87 368 1.00 
22 0.38 125 0.75 169 1.87 377 1.88 
27 0.38 126 0.75 174 1.38 378 1.38 


[ШЙ QUANTITY ШШ 


9601 Precision one-shot. 
74H40 High speed 7440. 3 ы 00 
MM5262 2K dynamic RAM. Many bits p . $1.25 
FPQ3725 Quad PNP transistor array, type 2N3725, in 
a DIP package. Get 4 FPQ3725s for. ..81.95 
745471 8х 256 fast ROM іп DIP package....... $9.50 
811.595/96/97/98  Tri-state LS octal buffers. .$1,13 
2102L1 Low power, 450 ns guaranteed for full temp 
range. Just Ani iis ear en ..91.95 
TERMS: Orders under $10 add 50¢ handling. No COD 
orders. Place Mastercharge® and BankAmericard® or- 


ders by calling 415-562-0636, 24 hours. California 


residents add appropriate sales tax. 


OQ DEDU 


BILL GODBOUT ELECTRONICS 
BOX 2355, OAKLAND AIRPORT, CA 94614 


While you're here...circle the reader service card. 


Our flyer will make ít worth your while! 
VYVYYYVVTVYYVVYVVYVVYVYY VY VVVV Y VVY VV T Y VY YYYYVYTT UT YYYY YYYY TYYYYYY 


GROUP DISCOUNTS: 
Buy 10 KITS, TAKE 104; 


COMPUTER CLUB MEMBERS MAY WISH TO POOL 
Buy 100, TAKE 20%. 


ГТ ГІ 


tHe! ve taken the 5204, a 4K EROM, 
rand programmed it with some soft- 
ате for your 8080, With this 
oftware, you may: 

i**Examine and fill memory 
i**Punch and read paper tape 
*Branch to, and recover from, 
programs. 

Our package consists of the pro- 
! grammed $204 as well as a com- 
‘plete software listing. 

puel cos--— CL edem mam. 1 P2-------------4-2---2--2-2-26-22--2 


THEIR ORDERS, 


AAAAAAAAAAAAAAAAA, 


Learn about PACE, the 16 bits 
microprocessor chip, with thi 
180 page booklet. Contains de 
i tailed and specific informa: 
‘tion on the chip itself, soft- | 
iware, system organization, and! 
«more, Also includes 11" X 17"! 
{fold-out logic print of РАСЕ! 
implementation, 


Loaner 


Continued from page 89 


Many people have done as | have, which is to 
put aside their 8008 and replace it with an 
8080A or newer generation equipment. This 
8008 unit which is kicking around can solve 
the chief disadvantage of vector graphics — 
software refresh. The 8008 is more than 
adequate to drive the controller with fixed 
data tables: Why not take advantage of it? A 
very reasonable solution is to dedicate your 
Scelbi, Mark 8, or what-have-you-kluge to 
run and refresh the display. The graphics 


Table 2: Refresh Vector Table for Drawing the Star Ship Enterprise. This 
table contains the information needed (in octal) to generate the Enterprise on 
a vector display. The addresses are relative to page 001, starting at location 
50, for use with the program of listing 2. The end of the display string is 
indicated by the octal code 377 found stored at location 330. If you were to 
put some extra imaging information in the picture, the additional vectors 
would begin at location 330 instead of the end code. The fine print numbers 
in figure 4 near each line segment are the addresses of the appropriate vector 


specification in this table. 


Vector start 

Address fx ҒА 
050 004 104 
054 014 070 
060 030 070 
064 054 060 
070 110 070 
074 120 104 
100 014 104 
104 040 110 
110 040 110 
114 042 114 
120 064 114 
124 046 114 
130 050 120 
134 060 120 
140 074 070 
144 104 034 
150 064 030 
154 064 010 
160 104 004 
164 140 004 
170 210 014 
174 204 024 
200 154 032 
204 140 034 
210 140 034 
214 074 032 
220 064 020 
224 054 030 
230 054 010 
234 054 020 
240 134 104 
244 134 130 
250 320 130 
254 304 104 
260 304 104 
264 170 104 
270 170 024 
274 154 024 
300 140 104 
304 134 130 
310 130 124 
314 126 120 
320 126 114 
324 130 110 
330 377 


С end 

x P commentary 
014 070 Begin Enterprise's bridge 
110 070 

054 060 

074 070 

120 104 

004 104 

040 110 

120 104 

042 114 

064 114 

070 116 

050 120 

060 120 

062 114 

104 034 Bridge connecting strut line 
064 030 Main body outline 
064 010 

104 004 

140 004 

210 014 

204 024 

170 027 

140 034 

104 034 

114 076 Bridge connecting strut line 
074 006 Phaser weapons bank 
054 030 

054 010 

064 020 

050 020 

134 130 Engine pod outline 
320 130 

304 104 

304 130 

134 104 

170 024 

154 024 Engine pod support strut 
154 104 

140 130 

130 124 

126 120 

126 114 

130 110 

134 104 


End of picture code 
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program and refresh vector table would be 
contained within the 8008 as well as a very 
simple communications driver which allows 
it to talk with your new 8080, Z-80, 6800 or 
what have you. Communication would be 
between a couple of parallel input and output 
ports. The 8080 system could contain all the 
number crunching routines and large pro- 
grams such as Space War while the 8008 
drew and refreshed the playing field or 
hyper space. Vector table updates would be 
sent from the main game processor to the 
8008 display processor periodically as the 
game progressed. This system would be 
fantastic. 


Bigger Displays 


While 5 inch scopes are quite adequate, 
full appreciation of vector graphics is re- 
alized only on large screen displays. Com- 
mercially sold large screen XY displays start 
at about $600. Hal Chamberlin, in his 
Computer Hobbyist articles mentioned 
earlier, describes how such a display can be 
built (with some difficulty) using television 
style display mechanisms. His work was an 
invaluable help to me in getting my display 
going; the circuits you see in this article are 
my adaptations of some of the circuits Hal 
published in his excellent publication in 
connection with his vector display design. 
The Computer Hobbyist is located at Box 
295, Cary NC 27511. At last report, back 
issues were available. 

Another possible source of big screen 
displays is auctions of electronic equipment 
(often attended by dealers in surplus), For 
example, Electronic News often publishes 


REFERENCES 


Worth noting are two articles which contain in- 
formation on vector graphics experimentation be- 
yond that contained in this issue of BYTE: 


Concerning the conversion of the Sanders 708 see: 


Ciarcia, Steve and Robertson, Carl L: 
"Simple Graphics Terminal Using Inexpen- 
sive Surplus Equipment," 73 Magazine, 
September 1976, pages 116-123. (The cir- 
cuits shown in figure 2 of the present article 
are revised versions of some of the circuits 
in author Ciarcia's earlier published work 
cited here.) 


Concerning the generation of character graphics for 
a vector display see: 


Lerseth, Richard J: “А Plot Is Incomplete 
Without Characters," BYTE, July 1976, 
pages 64-72. 


Concerning experimentation with a magnetic de- 
flection CRT display built from scratch, see: 


A series of graphics articles by Hal Cham- 
berlin in Volume 1, issues 1, 2 and 3 of 7he 
Computer Hobbyist. 
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Figure 4: The Star Ship Enterprise, drawn on a graphing grid. One way to prepare data for a display such as this is to plot it out 
ahead of time on a coordinate grid, such as graph paper. This figure was constructed using the data of table 2; but in the normal 
procedure the figure would be drawn first, and then one would prepare the table of vector specifications. 


auction announcements when they are held; 
and for those of us in the New England area, 
the Boston Globe auctions section has adver- 
tisements of electronic companies’ public 
auctions from time to time. 

In my own case, | purchased a surplus 
Sanders Associates 708 CRT terminal from a 
local surplus house. This terminal, sold 
through the 1960s and early 70s, is an all 
solid state video terminal which was used for 
alphanumeric display, typically in medical 
information systems. The terminal used a 
starburst generator for alphanumerics. This 
fact alone is enough for one to realize that it 
is in fact an analog vector scope. The 708 
CRT has a 12 inch screen and a P31 high 
persistence phosphor which makes for some 
tremendous graphics. | got mine for Jess than 
$200, and | found that it was readily 
converted to a 12 inch XY vector scope for 
this purpose. 

Whatever you choose as a display me- 
dium, whether it is a 5 inch oscilloscope or a 
12 inch XY display tube, you will find 
vector graphics both challenging апа 
fascinating. Printing out a message describing 
a battleship on an alphanumeric CRT is 
interesting, but it cannot hold a candle to a 
system which can draw a battleship com- 


plete with guns and flag on the screen. 
Graphics opens a new dimension for the 
home computer experimenter and it need 
not be prohibitively expensive. Using high 
performance peripherals such as this serves to 
complement a well designed computer sys- 
tem, and provide uses for oscilloscopes when 
everything is working right with your 
hardware.B 


OUTPUT 
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Photo 3: Using the graph- 
ics display for engineering 
outputs. This is а con- 
cocted display to illustrate 
XY plotting situations. 
Whatever “output” is, it 
varies with "time" in a 
ragged sawtooth defined 
by several vectors. 


CONTINENTAL SPECIALTIES CORP 


NEW PRODUCT ANNOUNCEMENT 


РС—40 
only $13.75 ----- lowest priced 40-pin ІС Test clip made today. 


MC14412 UNIVERSAL MODEM CHIP 
МС14412 contains a complete FSK modulator and de-mod- 
vlotor compatible with foreign and USA communications. 
(0-600 BPS) 
FEATURES: 
„Оп chip crystal oscillator 
. Echo suppressor disable tone generator 
-Orlginate and answer modes 
Simplex, half-duplex, and full duplex operction 
«On chip sine wave 
«Modem self test mode 
«Selectable data rates; 0-200 
0-300 
0-600 


» Single supply 
VDD=4.75 to 15VDC - FL suffix 
VDD=4.75 to 6 VDC - VL suffix 
TYPICAL APPLICATIONS: 
Stand alone - low speed modems 
«Built - in low speed modems 
.Remote terminals, accoustic couplers 
МС14412ҒҺ............».24%%% өш өш сө а өш... 528,99 
МС14412У1........ wee 521.74 
6 pages of [EE ‚60 


Crystal for the above......$4.95 


MC14411 BIT RATE GENERATOR. 

Single chip for generating selectable frequencies for equip- 
ment in data communications such as TTY, printers, CRT s 
or microprocessors, Generates 14 different standard bit 
rates which ore multiplied under external control to 1X, 
ВХ, 16X or 64X initial value. Operates from single +5 
volt supply. МС14411............... 8....... $11.98 
DET DNI "D ‚40 
Crystal for the абоуе....... $4.95 


COS/MAC Single chip CPU COP1802 from RCA is | 


8-bit register-oriented central-processing unit designed for 
general-purpose computing or control 

Flexible IO = Program Interupt mode 

On Chip ОМА ~ 91 Instructions 
СО?1802СО...........5+«+е«,ежввв ева в59»5*$29,95 


PRECISION REFERENCE AMP 

LH0070-1H provides a precise 10.0 volts for use in BCD A 
to D converters or meter calibrators. Typical initial accuracy 
is .3% (t .03V), Comes in ТО-5 con, 
LH0070-1H.... eee eee eee WII зрес............‚$5.35 


әрін 


TELEPHONE PULSE CONVERTER 

MC14409P is a device designed to convert a four bit 

binary input code to a number of serial output pulses for 

use in telephone dialing applications. When used with the 
МС14419Р (Key board to binary encoder) you сап make a 
touch type telephone dialer to control your rotating 

dial phone. Соп be used with a static RAM for reportoire 
dialing or use your computer to dial up numbers by name! 
МСІ4409Р................%%4%%<2< иа өм. 510,98 
МСТ4419Р. 
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NEW! 


Van Use 


‘overs ТЇЇ, OTL, Tri-State, etc. 
LINEAR, Covers amplifiers, pre-amps, op-amps, .. $3.95 
LINEAR APPLICATIONS, 
technical briefs covering the use of op-amps, regulators, 

phase locked loops and audio отрз...., Vol 1..... $3.25 


ТҮРЛІГІ 


Says 


Don't let your next project turn into 
a turkey ~ refute the tyranny of bad 
parts and poor service. Join the 
thousands who have found freedom 
of selection ~ make the crossing to 

TRI-TEK, Pilgrim. 


RGM 
GOLD CHIP 


Linear Integrated Circuits 


Brand new process by RCA in which the aluminum metalization 
has been replaced by goid, The chip is then hermetical ly seal- 
ed. Whot this means to you is unprecedented reliability and 
uniformity. Plastic parts that meet mil specs! | 

Tri-Tek is proud to be the first to bring this new level of 
performance to you at SURPLUS PRICES, Why buy regrodes? ? 


CA747C. . General purpose dual op-amp, 14 pin дір... 826 
| CA748C, Externally compensoted 741, 8 ріп dip......,49c 
CA1458, , General purpose dual op-amp. 8 ріп дір..... 69% 
САЗ401. Quad single supply (5-18V) op amp. 14 pin.. 89¢ 


Another super buy from RCA, CA555 timer, 8 pin dip. 59 


biu 
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ALPHA-NUMERIC KEYBOARD 
Made Бу Licon for Motorola Dato Systems. Includes full upper case alpha and numeric with separate 
numeric and cursor control pods. Self scanning with ROM encoder. These beautiful keyboards оге 
modern design and recent manufacture, 
Outputs are TTL compatible and have open collector buffers with resistive pull-ups. Encoding is іп 
ASCII with some special control codes. Code table is supplied. 
There are only о few of these high quality KB's and at our price they wort fast long.... $39.95 


BY NATIONAL SEMICONDUCTOR NEW NATIONAL BOOK---LINEAR APPLICATIONS VOL II 
Takes up where Vol | left you-All the latest linear devices. 
Along with Vol 1 you have a great source of application 
data on the most widely used devices as well os new types 
just appearing, 


53,95 


Dozens of application notes and 


CMOS Gates, Flip Flops, registers, functional blocks $3 
VOLTAGE REGULATORS, A must for anyone making а 
power supply. Complete theory including transformers, 
filters, heat sinks, regulators, е!с................. 53.00 
MEMORY, Information on MOS and Bipolar memories: 
RAMS, ROMS, PROMS and decoders/encoders.. ... 53.95 
INTERFACE, Covers peripheral drivers, level translators, 
line driver/receivers, memory and clock drivers, sense amps 
display driver and орїо-соир[епз...,............... $3.95 
(Outside U.S., add postage for 1.51Ь%\ 
SPECIAL FUNCTIONS DATA BOOK contains detailed 
information for specifying ond applying special amplifiers, 
buffers, clock drivers, analog switches and O/A-A/D 
Converter ргодисіз.................. 122 $3.25 
AUDIO HANDBOOK contains detailed discussions, 
including complete design particulars, covering many 


areas of audio with real world design examples... $3.25 


МР5-101 (2 required)... esos so 


Specs for both chips....caccuscesccccccvcacesvesee 91.00 


TELETYPE CODE CONVERSION CHIP 

MMS5220BL converts 5 level Boudot into 8 level ASCII. Use 

this chip to make your old TTY talk to your new computer. 

ММ522081..............44%6%4.4өеө ее өш. 518,00 
Specs for the above. .30 


MOS TIME BASE КЇТ. 

Only 1" X 1.5". Input 5 to 15 VDC, output is 60HZ 
square wave for portable or mobile clocks. PC board is 
drilled! МТВК-60Н2..................2..... 55,88 


INTRODUCTION ТО MICRO COMPUTERS 

New book from OSBORNE, 

The first edition of this classic wos а huge success. Now, 
due to the growth of information on the subject Osborne has 
expanded the work into 2 volumes. Vol | covers basic 
concepts, Vol II discusses real world micro computers. 
ІМС-002 Vol lee cveccacsnassevenece 24%-ы... $8,00 
1МС-002 Vol 11 


'NOTHER NEW BOOK FROM OSBORNE, 

"8080 PROGRAMMING FOR LOGIC DESIGN" explains 
how an assembly longuage program within a microcomputer 
system con replace combinatorial logic ---- for logic de- 
signers, programmers or anyone who is interested in real and 
powerful applications of the ubiquitous 8080. 


PLD-4001 oss scevennnseveasevecceseenevscseess0 98,00 


We poy shipping on all orders over $10 US, $15 foreign in US funds. Orders 
under $10, please add $1 handling. Please add insurance. Moster Charge 
and Bank America cards welcome, ($20 minimum) Telephone orders may be 
placed 11AM to 5PM daily, Mon thru Fri, Call 602-931-4528, Check reader 
service card or send stamp for our latest flyers packed with new and surplus 
electronic components. 


tRI-teék, Inc. 


6522 NORTH 43RÒ avenue, 
Glendale, arizona 85301 
phone 602 - 931-6949 
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function with a del and attempt to execute 
it? 


+—- APL 
NEW 

4—— APL 
TABLE OF SQUARES 

+ APL 
IL 

+ APL 
TABLE OF SQUARES 

+— APL 
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Something is wrong, so you reenter the 
function definition mode and list your 
function: 


УМЕН USER —> 

[6] я—— APL 
(0) USER —> 
VNEW 


[1] №0 
[2] 'TABLE OF SQUARES' 


ІЗІ NeN+1 «—— APL 
(4] N;N*2 


[5] +(NA10) /2 


The line which used to be 2 is now 3, since 
APL renumbers all lines to integers when 
you close the function. You could change 
the 2 to a 3 in the fifth line; however, there 
is a better way. If you have to insert or 
delete lines from your function again, all 
places where there is a branch arrow may 
also have to be changed. If APL did not 
provide a way around this problem, the 
language would not be as popular as it is. In 
a function you can specify a variable to 
become a label by putting it at the beginning 
of a line and following it by a colon. 
Whenever you execute that function the 
labels in it are automatically assigned the 
value of the lines where they are located. 
The function when corrected using a label 
would look like this: 


VNEW 
[1] N«O 
[2] 'TABLE OF SQUARES' 
+ APL 
[3] LOOPLABEL: N+N+1 
[4] N;N*2 
[5] +(N410) /LOOPLABEL 


The function NEW above is a niladic func- 
tion, which returns no result. Niladic means 


it has no arguments. Here is an example of a 
niladic function which returns a result: 


VRESULT-THISFUN 
[1] xX+A+B 
«— APL 
[2] RESULT+pxX 
V 


The function could be called inside an 
expression and used wherever a variable 
could be used. For example: 


АЄ1 +— USER 
B41 234 +— USER 
3+THISFUN <+— USER 
7 «—— APL 


THISFUN calculates the sum of A and B 
then finds the length of the sum and returns 
it as the value of THISFUN. In the function 


Proposed Micro APL Specifications 


Operators: 


All monadic and dyadic scalar operators wil! be 
implemented (except for the exponential, logarith- 


mic and circular if space does not permit). 
The following monadic mixed operators will be 


implemented: ravel, index generator, shape. The 
following will probably be implemented: grade up, 
grade down, execute, and reversal. Catenation, 
index of, reshape, and compression will be the 
dyadic mixed operators implemented, probably 
along with: take, drop, element of, rotate, and 
perhaps encode and decode if space permits. 

The only composite operator implemented will 
be reduction. 


Data Structures: 


Numeric and character data will be allowed, but 
all numbers will be stored іп ІВМ 360/370 single 
precision floating point format. Character data will 
be stored one character every four bytes to 
conform with floating point format. The space 
allocated for character and numeric data will be 1 
to 2 K, so the maximum number of elements in all 
variables and internal variables created by evalua- 
tion of an expression must be less than 256 to 512. 
Vector will be the only type of array allowed. 


Functions: 


Up to eight functions may be defined in 
workspace. The total memory for function storage 
will be around 1 to 2 K. Although the functions 
are stored in essentially the same format in which 
they are defined, a number of pointers also have to 
be stored in this area. Recursive functions and local 
variables may or may not be allowed depending on 
the amount of memory available. 


Total Memory Requirement: 


12K 8008 system. An 8080 or 6800 version 
could probably run in 8 K by reducing the amount 
of memory allocated to the workspace. 
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the value that will be returned is assigned to 
the dummy variable specified in the function 
header (in this case, RESULT). 

A function could also be monadic, as this 
function which finds the cosine of a num- 
ber: 


VC-COS X 


[1] C*20X +— APL 


V 


A monadic function which returns a result, 
such as COS, could be used anywhere a 
monadic operator is legal. (See table 1 for 
the meaning of symbols used.) Thus APL 
allows the programmer to effectively create 
new APL operators, which sometimes adds 
the readability of a program. An example of 
the use of this particular function is: 


(COS 02) + (COS 03) 


This is certainly more readable than 


2002 + 3003 


which would calculate cos (27) + cos (37). А 
dyadic function which returns a result could 
be used anywhere a dyadic operator is legal, 
so the function ADD could replace +: 


VAB-A ADD B 
[1] АВ<А+В 4— APL 

V 

34 2 ADD 4 6 USER — 
38 4 4— APL 


Table 2: Typical APL System Commands. 
These are the global instructions used to 
control the interpreter program. A small 
system APL would use versions of these 
commands. 


)CLEAR Clears all functions, variables, etc. 
ОАР Loads a new workspace from an 
auxiliary storage device. 

)SAVE Saves a workspace on an auxiliary 
storage device. 

)FNS Lists all functions in the current 
workspace. 

)VARS Lists all variables in the current 
workspace. 

81 Displays the state indicator (internal 


information about where execution 
stopped, and where errors have 
occurred). 


)SI CLEAR Clears the state indicator. 
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A dyadic or monadic function need not 
return a result such as this function: 


VAA SUM BB 4—— APL 
[1] 'THE SUM IS';AA+BB 4—— APL 
V 4—— APL 
2 PUM 4 USER — 
THE SUM IS 7 «АРІ 


However, it is illegal to use a function which 
does not return a result inside an expression. 

The previous discussion has shown what 
the typical APL functions are like. In addi- 
tion, there are usually several system com- 
mands associated with an APL interpreter. 
Table 2 gives a short listing of several typical 
system commands. These refer to the means 
of loading, clearing and saving the APL 
workspace, catalogs of what is in the work- 
space, etc. 

This should give you a good idea of the 
power of APL on a large system, but how 
useful would APL be on your small system 
byte banger? Obviously many of the opera- 
tors would take a good deal of the memory 
of an average small system to implement 
(matrix divide, for example). Another prob- 
lem is that since APL is so generalized in its 
operations, it is somewhat memory ineffi- 
cient. For example, to add two vectors, A 
and B, together, all you have to type is: 


A+B USER —> 


but, in order to calculate the sum, APL has 
to make a copy of each of the vectors first; 
so if the length of A and B is 64 (256 bytes 
at 4 bytes per floating point number), then 
1 K would be in use during this operation. 
Using a comparable program in BASIC 
would require 516 bytes, since the sum 
could be calculated one element at a time, 
printing each sum out as it was calculated. 
There is also an [O problem, since most 
people have ASCII encoded terminals (or the 
equivalent), terminals which do not have the 
entire APL character set on them. 

The only way ! see that APL could be 
practical for a memory and lO limited 
personal processor is if the features were 
limited (only vectors, for instance, instead of 
up to 63 dimensions for arrays), and if the 
number of operators were kept to a work- 
able minimum. All the scalar operators are 
performed in а similar manner, so they could 
be easily implemented. But only the most 
powerful of the mixed operators should be 
implemented, for example: 


1 p / % + 4 


Of the composite operations, reduction is 
the most used, and easiest to implement. 
Whether or not character data would be 
allowed depends on what size system was 
available. An easy way to handle character 
data would be to store one character every 
four bytes, so the routines used for numbers 
would not have to take care of the special 
case of character data. Although this method 


GLOSSARY 


Array: An array is a group of numbers (or 
characters) which in APL can be subscripted or 
treated as a single object. Vectors are the only type 
of arrays discussed in this article; however, a full 
implementation of APL allows matrices and up to 
63 dimensions for arrays. 


Character: As an APL data type, character is the 
kind of operand which is allowed for most mixed 
operators, but not for scalar operators other 
than = and #. 


Command: An APL system command causes some 
operation to occur, such as destroying the current 
workspace, or loading a new workspace from an 
external device. A command begins with a right 
parenthesis and has an English keyword, such as 
) CLEAR or ) SAVE. А command is normally legal 
in either execute or function definition mode. 


Compiler: A program which translates a high level 
source program into machine language object code 
is called a compiler. 


Composite operator: A generalized operator which 
takes a built-in operator(s) and performs it (them) 
in a special way. An example is reduction, which 
takes a scalar operator and performs it upon all the 
elements of the operand, right to left. 


Dyadic: A mathematical term meaning having two 
operands. An APL function or operator which is 
dyadic must have an operand on both sides of it. 


Execute mode: This is the APL system mode 
where an expression such as 1+1 will print the 
result. The del is used to leave the execute mode 
for the function definition mode. 


Function: This is the name of an APL program. 
Since a workspace may have more than one 
function and a function can be niladic, monadic, or 
dyadic, and may or may not return a result, 
functions can be used as main programs, sub- 
routines, or functions. 


Function definition mode: This is the mode in 
which APL functions are created. The del is used 
to go back and forth between the execute and 
function definition modes. 


Function header: This is the first line of a 
function, before the actual program starts. It gives 
information to the interpreter about the function: 
Does the function return a result? What, if any, 
local variables are used in the function? 


Interpreter: APL is implemented as an interpreter, 
a program which takes a source listing of the high 


would waste memory in the workspace 
proper, it would greatly reduce the size of 
the interpreter, and in a small system this is 
where most of the memory is used. On large 
systems, logical (1 and 0) data is stored as 
bit level data for memory efficiency, but on 
a small system the major programming prob- 
lem of unpacking bits would probably not 
be worth the small savings it would provide. 


level program and performs operations as the 
meaning of the program is being translated. 


Mixed operator: In APL a mixed operator is one 
that allows or requires the operand(s) not to obey 
the rule for the size and shape that scalar operators 
do require. 


Monadic: A function or operator which has only 
one operand to the right of the operator. 


Niladic: A function which has no operands. 


Operator: Ап operator is a built-in function which 
performs some common task such as addition, and 
is represented by a single, reserved, character. 


Quad: The quad is used in expressions to perform 
input and output, and in the function definition 
mode to list the function. To the right of an 
assignment arrow quad will request an expression, 
which will be evaluated, and the result used in 
place of the quad in the expression. To the left of 
an assignment arrow, quad prints out the value 
assigned to it, Quote-Quad is for input of character 
string data only. 


Rank: This is the shape of the shape of an array; in 
other words the number of dimensions of the 
array. 


Scalar: A single value, such as 8 ог 23.4. Scalars 
can be used with dyadic scalar operators to operate 
on all the elements of the other operand. 


Scalar operator: An operator which obeys this 
rule: if the size of the two operands (for the 
dyadic operation) is the same, do the operation on 
the values in parallel. If one or the other is scalar, 
do the operation between the scalar and all the 
elements of the other operand. 


Shape: In a full implementation of APL, this is a 
vector which represents the dimension of an array. 


Subscript: This points to which elements of an 
array are to be used. APL allows subscripts to be 
vectors, a feature most other languages do not 
allow. 


Variable: А symbolic name given to a value, such 
as 3, or 4. A local variable (dummy) is one which 
will be destroyed after the function in which it is 
in finishes executing. 


Vector: A one dimensional array, the only type of 
array which can be represented as a constant in 
APL. 


Workspace: The APL name for all the functions, 


variables, and internal state indication data which 
the user has created. 
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The storage problem of A+B could easily 
be avoided by writing a program similar to 
the one in BASIC: 

VNOPROBLEM 
[1] м0 
[2] LOOP: NeN+1 
+— APL 
[3] A[N]+B [N] 


[4] *(N£oN) /LOOP 


V 
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Figure 1: Two examples of 
alternate dot matrices for 
APL characters. The char- 
acter at the left is the 
Greek character rho, 
shown in an approxima- 
tion which distinguishes it 
from a Roman P. The 
character at the right is a 
Greek iota. 


In APL the programmer has the advan- 
tage of being able to choose whether or not 
he or she wants to use the built-in vector 
operator or program it, which is something 
that the programmer of most small system 
BASICs does not have. 

As far as the character set problem is 
concerned, a translation table could be built 
to translate ASCII input like $R (control R) 
into the internal code for o, or $1 into the 
internal code for 1. Once translated, the 
computer would not care if the 1 came from 
an APL terminal or even a Baudot Teletype. 
Or, an ASCII keyboard could be used when 
the internal codes for the АРІ. character set 
were chosen so that the positions of the 
characters on the ASCII keyboard simulated 
where the same key was on the APL key- 
board. An upper case | would be : while i 
would be translated into |. The same transla- 
tion would occur with R and o; r and R. 
On such a system a TV display could be 
converted to show a 5 by 7 representation of 
the character, as shown in figure 1. 

Of course, software would have to handle 
the translation from the internal codes to 
the graphics codes, and software would have 
to take care of the cursor; so that if the APL 
programmer backspaced to create a legal 
overstrike, such as ' over . to form !, or o 
over | to form 4, the rotate operator, it 
would appear as if the overstrike actually 
occurred. (On most CRTs, it would not 
have; but rather it would have been replaced 
by a new code, created by the software as 
soon as the backspace and corresponding 
overstrike were entered.) 

Some people love APL and some people 
hate it. | think it is one of the best 
interpreters around, next to BASIC. I hope 
to be able to implement a subset of APL on 
my computer in my spare time so that it will 
speak more than one language. I’m not sure 
how powerful a small system APL would be, 
but | will report my success or failure in a 
later article. In the meantime, l'd like to 
hear from anybody who is interested in or 
knowledgeable about small systems APL.m 


BROWN-OUT PROOF 
your ALTAIR 8800 


With the unique Parasitic Engineering constant voltage 
power supply kit. A custom engineered power supply for 
your Altair. It has the performance features that no simple 
replacement transformer can offer: 


Hot Off the Grapevine 


Texas Instruments has announced (in 
marketing literature of somewhat limited 
circulation) a new single chip video con- 
troller integrated circuit which is envisioned 
as part of the 9900 family line. This is a 
single chip generator for all the timing and 
control information needed to run a raster 
scan display interfaced to an LSI processor's 
bus. The grapevine says that it is being 
sampled at the present time, and will be on 
distributor shelves next spring. The same 
grapevine identifies a second, similar con- 
troller chip announced by another company 
as well. Either item would make excellent 
material for a tutorial review article in BYTE 
since these chips have obvious uses in per- 
sonal computing systems. 


*BROWN-OUT PROOF: Full output with the line voltage 
as low as 90 volts. 

*OVER-VOLTAGE PROTECTION: Less than 2% increase 
for 130 volt input. 

*HIGH OUTPUT: 12 amps @ 8 volts; 2 amps total 2 
ж 16 volts. Enough power for an 8800 full of boards. 

*STABLE: Output varies less than 10% for any load. 
Regulators don't overheat, even with just a few 
boards installed. 

*CURRENT LIMITED: Overloads can't damage it. 

*EASY ТО INSTALL: All necessary parts included. 


» only $75 postpaid in the USA. 


ot М 
ы o calif. residents add $4.50 sales tax. 


Editor's Pet Peeve: All you wonderful users 
of the English language, engineering subset, 
take note: A “baud rate" is a redundant 
abomination. The concept is data rate, some- 
times measured in units of baud which we 
take to signify bits per second. (The original 
definition of a rate measured in baud is a 
little more complex.)m 


Not just a pretty face: 
Morrow's presents a front panel with brains--- $249.95 


Combination front panel к 
CPU board speeds progra 
development and ichupging 


Replaces and upgrades ALTAIR/ 
IMSAI front panel and CPU 
boards, or forms the nucleus 
of a custom system. 


This isn't a toy...or a con- 
versation piece...but a tool 
for serious program develop- 
ment, rivalling the sophisti- @ 
| cation of many minicomputer | 
| systems. Granted no system 
| can make bugs go away: but 


Don't let power supply problems sabatoge your Altair 8800 


PARASITIC ENGINEERING 


PO BOX 6314 ALBANY CA 94706 


We've made some strong claims 


this one, finally, makes them : The "Slow Step" mode allows 


manageable. 


Two exclusive operating modes 
give you control over real 
time, allowing you to work on 
a program while it's running. 
The "Control Halt" mode ref- 
uses to let the 8080A CPU go 
dormant upon executing a HALT 
instruction; instead, special 
purpose hardware forces a NO 
OP instruction then passes 
control to the front panel 
program, where you can exam- 
ine and alter processor regis- 
ters...memory locations...and 
I/O ports directly from the 
front panel. 


you to run through a program 
at a variable rate from 1 to 
65,000 steps per minute. The 
display indicates the program 
counter and а processor regis- 
ter of your choice. 


Unambiguous readouts replace 
blinking LEDs; a 12 pad key- 
board replaces time-consuming 
toggle switches. And because 
the front panel/CPU is Altair 
buss compatible, you can build 
a custom system around this 
board using Altair compatible 
peripherals. Also compatible 
with any software written for 
an Altair type buss. 
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in this ай--- and given the 


f way some companies advertise, 


you have a right to be skep- 
tical. In order to dispel any 
doubts, we've put together a 
complete documentation packet 
(schematic, layout, software, 
assembly instructions), avail- 
able for $5.00 postpaid. You 
may be surprised to find out 


we've understated our case. 


WHO DARED ТО CHALLENGE THE 8080 & 6800 SYSTEMS? 


WE DID! 


| VERAS SYSTEMS 
GG F-8” 


Ty $459.90 KIT FORM 


7" x 16" x 14-3/4" 5709 20 ASSEMBLED and TESTED 


COMPARE STANDARD FEATURES ON BASIC SYSTEMS 
YOU’LL SEE WHY THE VERAS F-8 SYSTEM WINS HANDS DOWNIE ‘registered Trademarks of Fairchild and Motoroli 


; 8080 & 8080A 6800 
STANDARD FEATURES VERAS F8 ‘SYSTEMS SYSTEM 


Parallel 1/0 Ports | (3) 8 Bit Bidirectional Brought Out To Rear Panel Conn’s.J None — | None 
Serial 1/0 Port | RS-232 or TTY Brought Out To Rear Panel Term. Strip, § — — None — |  RS232orTTY __ 


Interval Timers (2) Programmable Interval Timers None mE 


a) Vectored Interrupt To Location 0090 Hex. 8) 2 Non Vectored 
b) Vectored Interrupt Programmable Location Interrupts on P 1 A 
Interrupts c) Two Vectored Interrupts Associated With Interval ч b) 2 Vectored S W I £ 
Timers | NMI 
d) Total of (4) Interrupts In A User Defined Priority с) Total of 4 Non Pri- 
Interrupt Structure oritized Interrupts 


Built In Mini Operating System 
in ROM For Terminal And | FAIRBUG* None MIKBUG* 
Memory Debug | 

| 3 Manual Console Automatic Internal 
Loader Program Automatic Internal ROM hac cd ROM 


Static RAM Memory 1024 BYTES | мов |  2048BYTES 


Rugged Alum. Self Contained Card Rack/Plastic Self 
Card Rack Aligriing Card Guides Card Supports None 


Auxiliary DC Power To +5V, -5V, +12V, -12V @ 1 Amp. Ea. Regulated At m wes 
Power Peripherals Rear Panel Terminal Strip ПЕ е 


$539.00, $599.00 ог 
Basic Kit Price $459.00 $840.00 Depending $395.00 
On System 


OUR 4K STATIC RAM BOARD FEATURES: (OPTIONAL) The More Flexible and Expandable 


е On board decoding for any four of 64 pages. © Address and data lines are fully buffered. Computer at a Comparative Price. 
* No onboard regulators to cause heat problems. (Chassis mounted) 00 
* 4K memory boards with connector, buffers, static RAM's & sockets are available in kit form $1 49 VERAS SYSTEMS 
The VERAS System can be made into a 
17K ipe by теу асраар of ou TH E VERAS SYSTEM Warranty: 90 day "— 
optional memory boards. The kit includes : ays on parts and labor for 
everything you need to build the VERAS F-8 Computer as described. All boards, connectors, assembled units. 90 days on parts for kits, 
switches, discrete components, power supply and cabinet are supplied. Programming manual, Prices, specifications, and delivery subject 


data book and simplified support documentation supplied, 8K Assembler and Editor {paper to change without notice. 
tape or К.С. std. cassette) available on request with minimum order of 8K RAM. 


è Two !/O ports each on the CPU and ROM chip make 32 bidirectional ТТІ lines. 
* The Fatrbug’ programmed storage unit provides the programmer with all 3 . 
TH E CPU ПО subroutines, allows the programmer to alter ar display memory, and A Div. of Solid State Sales, Inc. 
register its contents via teletype. Box 74B, Somerville, MA 02143 
BOARD Programmable internal timer is huilt into the ROM chip. (617) 547-1461 


Built in clock generator and power on reset are built into the CPU chip. 


It is expandable to 65K bytes of memory. O Enclosed is check for $ 
20 mil loop and/or RS232 interface included. 
1K of on board 2102 RAM. or O Master Charge # 


* Serial interface built into PSU chip. O VERAS F-8 Computer Kit O Assembled 


. 
. 
* There is a locat interrupt with automatic address vector. 
е 
. 
e 


*Fairbug is a registered trademark of Fairchild Corp. 


O 4K RAM Board Quantity 


TINY 2 K BASIC (avAILABLE) ОСТ. 15, 1976 $25.00 | name 
FULL BASIC (avaiLABLE) DEC. 15, 1976 $50.00 | “е 


City, State 


Computer dealers and hobbyist club inquiries are invited. Expected delivery time 30 days or less. 


SOLID STATE SALES 


PO ВОХ 74B 
SOMERVILLE, MASS. 02143 


WE ARE LEADING THE WAY IN CUS- 
TOMER SERVICE AND DELIVERY 
TIME FOR THE COST CONSCIOUS 
SEMI-CONDUCTOR USER, LARGE OR 
SMALL. 


TRIACS ` 


INTEGRATED CIRCUITS 


INTEL 8080 CPU ... 
2518-HEX 32 BIT SR 

2102.1 1024 BT RAM . EM 
5280 4K DYNAMIC RAM.. 
5202A UV PROM 

MM5203 UV PROM. 

1702A UV PROM 

5204-AK PROM 


2. $24.50 
. $6.00 


1.80 
$12.50 
$12.50 
$12.50 
$12.50 


MINIATURE МОСТЕТОВА TRIM POTS 


100, 500, 2K, 5K, 10K, 100K, 700K 


5.75 euch 


.3/52.00 


MULTI TUFIN TRIM POTS Similar ta Bourns 
3010 style 3/16x5/8^x1 1/4"; 50, 100, 


ТК, ТОК, SOK ohms 
$1.50 va. 


3/$4.00 


LIGHT ACTIVATED САУ 
TO-18, 200V 1A 


2N3585 NPN Si ТО-66 .... 
2N3772 NPN Sı TO-3 
2N4908 PNP Si ТОЗ... 


2N6055 WPN S; TO-3 Darlington . 


2N5086 PNP 5, TO-92 
2N4898 PNP TO-66 
2N404 PNP GE ТО-5 
2N3919 NPN $i TO-3 RF 
MPSA 13 NPN Si ТО.92 
2N3767 NPN Sı ТО-66 
2N2222 NPN Sı ТО-18 
2N3055 NPN 51 TO-3 
2N3904 NPN Si TO-92 
2N3906 PNP Sı TO-92 
2М5296 NPN Sı ТО-220.... 
"2N6109 PNP Si ТО-220 
2N363B РМР Si TO.5 
2N6517 NPN ТО-92 5, 


CIMOS (DIODE CLAMPED) 


74CO2 4016 

74C10- 25 4017 30 
4001 25 4018 40 
4002 25 4019 GU 


4006 160 4022 20 4050- 
4055- 1.20 
4066- 1.20 
4010 60 4025 25 4071 


4007 25 4023 25 
4009 .60 4024 25 


4035- 1.78 
4042- 1.60 
4047- 2.60 
4049- .70 


70 


30 


4011 25 4027 65 4077- .70 


4012 25 4028 150 
50 4029 1/5 
140 4030 90 


LED READOUTS 


NS 33-3 dig. array 
DL 7A7 


4081- 35 
4076- 1.20 


Send 25с for our catalog featuring 


Transistors and Rectifiers 


145 Hampshire St., Cambridge, Mass. 


Terms: FOB Cambridge, Mass. 
Send Check or Money Order. 


Inctude Pos: 
Order $5.00, СІ 


.5V at 500 та. .... 


PRINTED CIRCUIT BOARD 


4-1/2" x6-1/2" SINGLE SIDED EPOXY 
BOARD 1/16" thick, uartchedt 
$.50 ea. PN 
VECTOR BOARD 1" SPACING 
4.5" x 6" SHEET 


4WATTIRLASER DIODE $7.95 


2N3820PFET .............. $ 45 
2N5457NFET .... . 2-. 5 45 
2N 4891 UJT s e. 2-. 5 .45 
TIS43 UJT . en 5.25 
ЕН 900 TRIGGER DIODES, . 4181.00 
2N 6028 PROG. UJT 


Б/52.20 


VERIPAX РС BOARD” 
This board is a 1/16" single sided paper epoxy 
heard, 4:27 x6” DRILLED and ETCHED 
which will hold up to 21 single 14 pm IC's 
өз B, 16, or LSI DIP IC's with busses for 
power supply connector. 
MV 5691 YELLOW-GREEN 
BIPOLAR LED 
MT-2 PHOTO TRANS 
RED, YELLOW, GREEN OR 
AMBER LARGE LED's 
34 PIN DIP SOCKETS . . 
16 PIN DIP SOCKETS ... 
MOLEX PINS 


100/ 51.00 
1000/ 57.50 
8 PIN MINI DIP SOCKETS 5 
10 WATT ZENEHS 2.9, 4.7, 5.6, В 45, 

18, 22, 100, 1500: 200У ... 3 
1 WATT ZENERS 4.7, 5.6, 10, 12, 15, 
18 OR 22V 


PRV 1A. 


100. 06. 
200 107 
400 .09 
600 11 
800 45. 
1000 20 


SILICON SOLAR CELLS 
2%" diameter 
$5.00 ea., 6/$27.50 


REGULATED MODULAR 
POWER SUPPLIES 
4-15 VDC АТ 100ma 
TISVAC INPUT . . 
SVDC AT 1A. T15VAC INPUT |. . 
12 VOC AT b АМР 
IN 4148 (1М914) 


15/51 00 


TANTULUM CAPACITORS 


G.BUF 35V 3/$1.00 
22UF 35V $ 40 
33UF 35V $ .40 
1UF 35V 5 $1.00 "UF GV — 5/$1.00 
3.3UF 35V 4/$1.00 1000Е 35V 5.50 
4.3UF 35V 4/$1.00 150UF 15У $ 40 


.22UF 35V 5/$1.00 
ATUF 35V 5/$1,00 
68UF 35V 5/51.00 


‘M7001 ALARM CLOCK CHIP. ... 56.00 


NATIONAL MOS DEVICES 
ММ1402 1.79 MM5057 - 2.25 
MM1403 1/5 ММ5058 2.75 
ММ1404 1.79 ММБОБО 2.75 
MM5013 2.50 MM5061 2.50 
ММ5016- 2.50 ММ5555- 4.75 
ММБ017- 2.70 ММ5556 4.75 

055- 2.25 ММ5210- 1.95 
МЯ 2.25 


TTL IC SERIES 
7441 74126- .60 
7442 85 74150- 1.00 
7445 75 74151- 80 
7446. 80 74153 79 
7447 69 74154 1.05 
7448 77  74155- 1.00 
7472. 40 74157- .75 
HW». 74161- 1.00 
7474 74164- 1.05 
7475 | 74165- 1.05 
7476. 74173 95 
7480. 74174 1.20 
к 74175 9b 
7492 : 74177- 1.00 
7486. 74180- 1.00 
7489 2. 74181-2.40 
390 . 74190- 1.15 
J491 | 7419) -1.10 
3492 | 74192- BO 
J493 40 74193- 90 
УШ 74194- 1.25 
$95 | 74195- 774 
7496 74196- 1.10 
74107. 15324—1.75 
24121 | J5491 .60 
74123 0. 75492— .60 
74125 


MINIATURE DIP SWITCHES 
CTS.206 4 Four SPST switches 
in one munidip рас . . .$1.50 
CTS-206.8 Eight SPST switches in a 16 
pin DIP package . $2.55 


5 1013-A30K sei /par., par serc., Uni- 
versal UART. 


MTA 106 SPDT 
MTA 206 DPDT 


SOLID STATE SALES 


P.O. BOX 748 


SOMERVILLE, MASS. 02143 TEL. (617) 547-4005 


SANKEN AUDIO POWER AMPS” 


Si 1010 С 10 WATTS. 
Sı 1020 G20 WATTS... | 
Si 1050 G 50 WATTS 


CCD 110 LINEAR 256 ХІ BIT SELF 
SCANNING CHARGED COUPLED 
DEVICE 


.$ 690 


_ .. $99.00 


CCD 201 100 x 100 CHARGE 
COUPLED DEVICE . 


$135.00 


LINEAR CIRCUITS 
LM 309K 5V 1A REGULATOR 


723 - 40 + 40VV REGULATOR . . 


301/748-Hi Per. Op. Amp. 

3207 5, 12, 15, OR 24V 
NEGATIVE REG. 

709С Ор. Ати» . 

741A ог 741С OP АМР. 

710 COMPARATOR 

СА 3047 Hi Ре!. Ор. Amp. 

340T 5, 6, 8, 12, 15, 18, 24V POS 
REG. TO-220 


101 OPER. AMP. HI PERFORM... 
LM 308 Оре. Amp., Low Power . . 


747 -- DUAL 741 

556 - DUAL TIMER 

537 

LM 3900 -- QUAD OP. AMP 
LM 324 — QUAD 741 

560 PHASE LOCK LOOP 
561 -- PHASE LOCK LOOP 
565 - PHASE LOCK LOOP 
566 FUNCTION GEN. 

567 - TONE DECODER 


LM 1310N FM STEREO DEMOD. . 


8038 IC VOLTAGE CONT. OSC. 
LM 370 — AGC SOUELCH AMP. 
555 – 2us - 2 HR, TIMER 

553 OUAD TIMER 

FCD 810 OPTO-ISOLATOR 
1458 DUAL OP АМР. 

LM 380 — 2W AUDIO AMP. 

LM 377 — 2W Stereo Audio Amp. 
LM 381 — STEREO PREAMP, 


LM 382 - DUAL AUDIO PREAMP 


LM 311 HI PER. COMPARATOR 
LM 319 — Dual Hi Speed Comp. 
LM 339 — QUAD COMPARATOR 


TRIACS 
PRV ЛА 10A 


100 40 70 
200 1.10 
400 1.10. 1.60 
600 1.70 2.30 


WE SHIP OVER 95% 
OF OUR ORDERS THE 
DAY WE RECEIVE THEM 


$i 


15 
50 
31 


.50 
31 


You'll Want to Nybble at these 


Byte Books 


е Тһе TTL Cookbook by Don Lancaster, published by 
Howard W Sams, Indianapolis, Indiana. Start your quest for data 
here with Don's tutorial explanations of what makes a TTL logic 
design tick. 335 pages, $8.95. 


е The TTL Data Book for Design Engineers, by Texas 
Instruments Incorporated. How does an engineer find out about 
the TTL circuits? He reads the manufacturer's literature. This 
640 page beauty covers the detailed specs of most of the 7400 
series TTL logic devices. No experimenter working with TTL has 
a complete library without The TTL Data Book for Design 
Engineers. Order yours today, only $3.95. 


e The Supplement to The TTL Data Book for Design 
Engineers, by Texas Instruments Incorporated. What happens 
when you can't find a 7400 series device listed in The Data Book 
for Design Engineers? Before you start screaming and tearing 
your hair out in frustration, turn to the Supplement. The 
Supplement has 400 pages of additional information including a 
comprehensive index to both TTL Data Book volumes. To be 
complete (and keep your hair in place and vocai cords intact) 
you'd best order the supplement at $1.95 to accompany the 
main volume. 


* The Linear and Interface Circuits Data Book for Design 
Engineers, by Texas Instruments Incorporated. When you run 
across one of those weird numbers like 75365 the immediate 
frustration problem occurs again. What kind of gate could that 
be? We won't tell in this ad, but you can find out by reading the 
specifications in The Linear and Interface Circuits Data Book for 
Design Engineers. You can interface your brain to the 72xxx 
(linear) and 75xxx (interface) series of functions by ordering 
your copy of this 688 page manual at only $3.95. 


е The Semiconductor Memory Data Book for Design 
Engineers, by Texas Instruments Incorporated. Don't forget the 
importance of memories to your systems. Refer to this 272 page 
manual to find out about the TI versions of many of the popular 
random access memories and read only memories. Order your 
personal copy today, only $2.95. 


TTL Cookbook @ $8.95 
TTL Data Book @ $3.95 
Supplement to TTL Data Book @ $1.95 
Linear and Interface Circuits 9 $3.95 
Semiconductor Memory Data @ $2.95 
Transistor and Diode Data Book @ $4.95 
Power Semiconductor Handbook @ $3.95 
Understanding Solid State Electronics 9 $2.95 


Send to: 


Optoelectronics Data Book @ $2.95 СХЕ 
BANKAMERICARD. 


EUIE PETERBOROUGH, NH 03458. 


Where does the editor of a computer magazine turn 
when he must verify some author's hardware design? 
Information on a 75450 interface gate, or a 74147 
priority encoder circuit does not spring forth by magic. 
Checking the information supplied by authors is part of 
BYTE's quality control program. 

When you build a project, you need this same sort of 
information. All you find in the advertisements for parts 
are mysterious numbers identifying the little beasties . . . 
hardly the sort of information which can be used to 
design a custom logic circuit. You can find out about 
many of the numbers by using the information found in 
these books. No laboratory bench is complete without 
an accompanying library shelf filled with references — 
and this set of Texas Instruments engineering manuals 
plus Don Lancaster's 774 Cookbook will provide an 
excellent starting point or addition to your personal 
library. 


* The Transistor and Diode Data Book for Design Engi- 
neers, by Texas Instruments incorporated. You'd expect a big 
fat data book and a wide line of diodes and transistors from a 
company which has been around from the start of semicon- 
ductors. Well, it's available in the form of this 1248 page manual 
from TI which describes the characteristics of over 800 types of 
transistors and over 500 types of silicon diodes. This book covers 
the TI line of low power semiconductors (1 Watt or less). You 
won't find every type of transistor or diode in existence here, 
but you'll find most of the numbers used in switching and 
amplifying circuits. Order your copy today, only $4.95. 


* The Power Semiconductor Handbook for Design Engi- 
neers by Texas Instruments Incorporated. To complement 
the low power transistor handbook, Т1 supplies this 800 page 
tome on high power transistors and related switching devices. 
Here is where you find data on the brute force monsters which 
are used to control many Watts electronically. Fill out your 
library with this book, available for only $3.95. 


* Understanding Solid State Electronics by Texas Intru- 
ments Incorporated. This is an excellent tutorial introduc- 
tion to the subject of transistor and diode circuitry. The book 
was created for the reader who wants or needs to understand 
electronics, but can't devote years to the study. This 242 page 
softbound book is a must addition to the beginner's library at 
only $2.95. 


* The Optoelectronics Data Book for Design Engineers by 
Texas Instruments Incorporated. This 366 page book is a 
compendium of information on TI phototransistors, LEDs and 
related devices. Order yours at $2.95. 


Please allow six weeks for delivery. 


Name 

Address 

City State Zip 
H Check enclosed 

о Bill MC € Exp. Date 

a Bill BA € Exp. Date 


Signature а. 


Please add 25 cents for each book for postage and handling. 


Its all right here 


E Prompt service 
m In-depth inventories 


a BRI G А В: for INDUSTRY 
LOW, LOW PRICES! 


©) егестгопісѕ 


Offices & Warehouse: 10 Alice Street, Binghamton, New York 13904 » Tet.: 607-723-3111 


SAVE 


MINIATURE LAMPS 


CHICAGO MINIATURE LAMPS #387 
SAME AS #327 EXCEPT LONGER LIFE 


28 volts. .04 amps. Bulb Style T-1-3/4 
Mid-Plange Base. BRAND NEW BOXED, 100 
per box. 40,000 pcs in stock. 


PRICE SCHEDULE 
406 each 100 - up .. 


es 


NE-2 neon lamps, with dropping resistor 
to operate directly from 115 Vac. 
Nominal Watts - 1/17.  T-2 Clear Bulb, 
wire terminals. 

25,000 pes in stock. Mfd by G.E. Co. 
10¢ each uo to 1000 pes. 

1000 pes & up 7¢ each. 


i- 99 .. 


NION INDICATING GLOW LAMPS 


35¢ ea. 


SAVE 


Computer Grade шг 


MALLORY 


CG (STANDARD) 85°C Supplied with PVC Insulating Sleeve 


Size Each 
1-25/64 x 2-11/64 $.75 
1-25/64 x 2-11/64 .50 
1-25/64 х 2-11/64 +60 


Mfd. уас 
10000 1100 35 

25000 100 350 
10000 80 400 


Quan. 


POTTER SUB-MINIATURE 


Б BRUMFIELD GeNeRaL 


RE LAYS PURPOSE 


ТҮРЕ КН 5505 (Identical to КІШ)17011) 
COIL: 24vdc, 650 ohms. 
CONTACTS: 4PDT, 3amps at 30vde or 120 vac 


Small rugged ОС relay with clear poly- 
carbonate dust cover. Contacts are gold 


Electrolytic Capacitors 


TUBULAR, HIGH RELIABILITY 


“Ee 


су бу бу сусло ш 


QUAN 


899 
437 
400 
1360 
820 
4200 
400 
771 
417 
1100 
1100 
1600 
565 
4000 


VDC 


100 
100 
100 
150 
200 
200 
200 
200 
200 
400 
400 


flashed silver. 

Mounts by solder terminals or 3-48 stud 
5/16" long. Also mounts as plug-in. 
6500 pe in stock, BRAND NEW, while 
last at this price. $1.25 each 


INDICATOR LIGHTS 


BRITE-GLO Incandescent Lamps N 


Ultraminiaturized Series, 100,000 hr.life 
Versatile, low cost indicator lamp. Ideal 
for Stero Amplifiers, Mobile Equipment, 
Instrumentation, Computer and Display 
Panels, Etc. 

High temperature, T l-3/4 lamps ~ Metal 
Base - Wire Terminals. Metal base in- 
creases light output and protects lamp 
from damage. 

41, 685 pcs - 6.3 volts, 
leads. 

40,263 pcs - 6.3 volts, 
leads. 


they 


BRITE GLO INCANDESCENT LAMPS 


LAMINATED PHENOLIC 
PLASTIC PANELS 


HiGH POWER DUMMY LOAD 


Mfg. Eastern Microwave. #10-1254...RF Coaxial Load Re- 
sistor utilizing water flow to cool and provide a load 
resistance of 50 ohms for inputs from DC to 4000 MHz. 
Maximum power input is 1000 watts. Requires a flow of 
.218 GPM min. per 100 watts of input power; 100 psi 
pressure. Compression fittings on water line inlet and 
outlet for copper tubing supply lines. Has a Flange 
type coaxial fitting, friction type, 13/16" I.D. with 
2-1/4" flange. Completely shielded unit of machined 
aluminum. Size: 1-5/8" diameter by 5-3/8" long. 
Shipping weight, 2 lbs. 

5,000 pcs in stock, NEW BOXED 


BRAND NEW PHENOLIC SHEETS 
Srade LE- 
Type - FBE, Mil Spec: 15035, .062" thick 
Needed by all experimenters, amateurs and 
radio men for insulating parts - terminal 
Strips - building sets or for research 
& development, etc. 
Stock # 560 - 6" x 6" x 
8" wire " # 561 - 6" x 12" x .062 826 each 
" # 563 - 12" x 12" x .062 $1.58 ea 
" # 564 - Full sheets 38" x 47" x .062" 
$13.00 each. 
BRAND NEW QUALITY 


Natural 


.062" 42€ cach 


75 ma, 


200 ma, 13" vire 


DISCOUNT SCHEDULE SHEETS 
1- 99 25€ ea. 
100-499 20€ ea. 
500-999 15€ ea. 
1000-UP 12€ ea. 


High-Speed Reset Counter Cherry Electrical Products 


Veeder-Root 


A FIGURF CO 
ТІЗУЮС 115V; 
VEEDER ROOT 177604 

П5УАС (Rectifier supplied t. Basic 
counter is LISVDC, 6 walts 1 беше, 
black on white background. Push button 
reset, Dim. 1-7 8" width 1-1 8" hiph 
x 2-1 2" deep. 


LIGHTED 
PUSHBUTTON SWITCHES 


Unit can be used on 6 v 
909 . ` " or in series for 12 volt 
10 . % SPST, mom, PC board gold 
15. £&plated pins for wiring or 
28 . € easy installation. 

53. . et 10,000 pcs in stock 


90. А 
Mfr: Grayhill widely used on computers, machine tools, 
Switch Co. office machines, guidance control and а 
2" x 15" x 1%" wide variety of applications. 


n 


SIZE PRICE EA SIZE PRICE EA 


1-3/8 x 4-3/16 .50 2" x 4-1/2" 51. 
60000 5 3" x 4-1/2" .50 2" x 4-1/2" 
25000 6 2-1/16" x 4-9/16" .50 1-3/8" x 3-1/8" 1. 
40000 7 2" x 5" +50 1-25/64" x 2-11/64" 
15000 2" x 4-1/8" i“ x 3-1/2" 
15500 2" x 4-7/16" 2" x 4-1/2" 
40000 3" x 4-1/2" 1-7/16" x 2-9/16" 

x 

x 


These switches are postage 

stamp sized precision swit- 

ches which feature long op- 

erating life & high electrical capacity for their size 
5 amp, 1/4 HP, 125-250 vac, SPDT, quick dis-connect 
terminals. 2,000 pcs in stock without lever..75¢ each 
2,400 pcs in stock with extended roller lever. 956 ea 


ETER MANGAL RESET 


BARGAINS |PIRECISION —em— 
—e»— RESISTORS 
"TEMERE. - 


$25 


TANTALUM CAPACITORS 
SPRAGUE 
TYPE 109D 
TUBULAR SINTERED-ANODE TANTALEX CAPACITOR 


3109D147X9060T2 
1620 pcs - 140 uf %10% - 60vdc 


GENERAL (fb ELECTRIC 


BRAND NEW — FINEST QUALITY 


MPR TOL. OHMS WATTS PRICE 
(8) Each 


$.04 


$2.95 Each 


T.I. 
Electra 
IRC 
T.I. 
cr... 
T.I. 
Electra 
Electra 


191 
191 
243 


2. 43K §2.00 ea. 


PLAIN FOIL TANTALUMS 4-125? С 
(ле CLJi instead of CLIO; er, CLII 


intiead at СЫ! fer Mylar sleeve) 
CL10/ —POLARIZED. 
3,000 pes CLI1BEL80MPE, 18uf - l5vdc 65€ each 
300 pes CL31BESSOMPE, 55uf - l5vdc 856 each 
non-polarized CL32/33 


900 pcs CL33BLO20MNE, 2.0uf - 75уіс $1.00 each 


pa МТР/МТРН ULTRA-MINIATURE TANTALUM CAPACITORS 
MALLORY 


Minimum Order $5.00 
NY State Residents 
please add sales tax 


All Orders Ғ.О.В. 
Binghamton, NY. 


PREP EP REP Ree н н 


МІР TYPES IL———- 
10,550 pes MIP685MO20Pl1D, 6.8uf - 20vdc 55% each 
2,100 pcs МГР106МОЗОРІЛ, 100Е - 30уіс 756 each 
1,028 pcs MIP336MOLOPLA, 33uf - lOvdc 65% each 


Computer Grade Capacitors 


Instant off-the-shelf 
delivery. 


AS SOLID ELECTROLYTE YANTALUM CAPACITORS 
310%, 6vdc, ТА5475К006Р1А 35% ea 
10%, 6vdc, ТА5474К006РАА 386 ea 
10%, vdc, TAS476K006PlC 40¢ ea 
20%, 6vdc, ТА5227М006Р16 $1.20 ea 
285 pcs, 5.6uf + 10%, lOvdc, ТА5565К010Р1С 40€ ea 
4574 pcs, lOuf +104, lOvdc, TASIOSKOlOPlC 406 ea 
900 pcs, 1Suf %20%, 10удс, ТА5156М010Р1С 40€ ea 
887 pcs, .068uf +10%, 20vdc, TAS683K020PlA 51$ ea 
152 pes, 2.2uf t 20%, 20vdc, Sprague 40€ ea 
1457 pcs, .47uf +10%, 35vdc, TAS474K035PlA 516 ea 


GENERAL (f ELECTRIC PLAIN FOIL TANTALUMS +1139 € 
365 pcs G.E.  40uf,t20$, SOvdc, 125°C 
Tvpe: 2K105AA6M. $1.75 each 


1168 pcs SPRAGUE, 400#, +20%, 50vdc, 1250C 
Type: 220D005A3M. $1.75 each с 


4996 pcs, 4.7uf- 
394 pcs, .47uf 
1430 pcs, 47uf 


MFD. VOLTS 
326 pes, 220uf 


30000 5 


74000 3" 4-3/4" 1-7/16" x 2-1/2" 
15000 2" 4-1/2" 2-1/16" x 2-3/8" 
14000 2" x 4-3/8" l-1/2" x 4" 

10000 2-1/16" x 4-1/2" 1-25/64" x 2-11/64" 
12500 2" x 4-1/6" 1-25/64" x 2-11/64" 


If you want to be placed on our active mail 


BRIGAR ELECTRONICS publishes a monthly flyer 
list,send us your Name 


Production Description: 


Photo 1. 


The Astral 2000 


Editor’s Note 


This descriptive sum- 
mary is based upon materi- 
als supplied by M&R En- 
terprises, as well as first 
hand inspection of proto- 
type hardware during a 
trip to California in April 
of this year. The market- 
ing and development of 
the Astral 2000 is, to say 
the least, cautious and 
painstaking. It has been 
essentially kept | under 
wraps until the BASIC fa- 
cility was sufficiently de- 
veloped to allow release. 
The system has been 
shown off іп bits and 
pieces throughout the de- 
sign process by people 
from M&R who attend the 
sessions of the Homebrew 
Computer Club in Palo 
Alto CA. Now that M&R 
Enterprises is finally to the 
point of delivering the 
systems in initial produc- 
tion quantities it leaves the 
rumor stage and becomes a 
full fledged contender in 
the marketplace. ... CH 


The Astral 2000 system is based upon the 
Motorola 6800 central processor design. The 
use of any one of the many microprocessors 
is subject to numerous design choices in the 
details of how the chip will be buffered and 
interact with the rest of the computer world. 
The designer of the Astral 2000 computer 
chose to take a route which seems inherent 
in the design simplicity of the second genera- 
tion microprocessors such as the 6800. The 
Astral 2000 bus is a minimum complexity, 
minimum pinout design which in essence 
simply buffers the processor pins of the 
6800. As a result, it fits into the standard 44 
contact (dual 22 pin) edge connectors which 
are widely available at moderate cost. (This 
choice of a minimum pinout backplane 
configuration also makes it possible for this 
computer to use standard Vector Electronic 
Co cards as the basis for homebrew peripher- 
al interfaces.) This simplicity of the back- 
plane bus and use of standard connectors is 
one of the most elegant features of the 
Astral 2000. 

Without indulging in a major review, here 
in summary is what the 6800 processor 
chosen for the Astral 2000 will give the 
programmer in machine assembly language: 

1 index register (16 bits), 

1 stack pointer register (16 bits), 

2 accumulators (8 bits), 

1 flag register (6 bits active), 

5 addressing modes for data operations 
(direct 8 bit, extended 16 bit, immedi- 
ate, indexed with 8 bit offset, and 
inherent operands), 

4 addressing modes for processor con- 
trol operations (relative with 8 bit 
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signed offset for branches, jumps and 
subroutine calls, with extended 16 bit 
addresses or addresses indexed by 8 bit 
offset, and inherent operands for mis- 
cellaneous processor control instruc- 
tions), 

Data control manipulations include the 
usual and expected operations of a good 
general purpose instruction set in the second 
generation of microprocessors. Also worth 
noting are a decimal adjust instruction to 
handle packed decimal data and push and 
pull operations for the accumulators uti- 
lizing the stack as temporary data storage. 
The processor has a software interrupt, a 
reset sequence, a maskable interrupt line, 
and a nonmaskable interrupt line; all of 
these except the reset completely save the 
processor state prior to the beginning of the 
new instruction sequence. These interrupt- 
like operations are vectored to a new pro- 
gram location via 4 pointers located in the 
last 8 bytes of address space (locations FFF8 
to FFFF.) For more complete description of 
the 6800 architecture see the Motorola 6800 
literature. 

As implemented in an Astral 2000 sys- 
tem, the first 56 K bytes of a total 64 K 
bytes in the 6800 memory address space are 
left open for ordinary programmable memo- 
ry, the single most valuable resource of any 
general purpose processor's central proces- 
sing unit. What this means is that the user 
can insert cards in increments of 8 K to the 
point where some level less than or equal to 
56 K has been acquired. (This assumes that 
there are enough card slots in the backplane 
to accommodate such an expansion.) M&R 
Enterprises presently has available both an 8 
K programmable memory board and an 8 K 
EROM board (using the 5204 UV erasable 
chips) with which to take advantage of 
memory address space. The standard pack- 
age of the Astral 2000 includes one of the 8 
K programmable memory boards. The upper 
8 K of a Motorola 6800's address space is 
reserved for the system monitor and periph- 
erals of the Astral 2000 design. 


The Monitor and IO 


The basic concept of the Astral 2000 is 
that of a "turn key" system, even when the 
unit is purchased in kit form. An aspect of 
this is the preassembled and tested processor 
board and memory board. Another aspect of 
this is in the physical configuration seen in 
the photographs. The front panel may seem 
at first sight to be an unimaginative repeat of 
the traditional front panel seen in computers 
from time immemorial. But it is not essen- 
tial, and is put in the design apparently for 


r— SE Lomme-—-——-- ee | 
FAIRCHILD ANNOUNCES THE FAIRCHILD 
a a ee dm cum — GÀ ——— — M 


SOLID STATE TECHNOLOGY KIT 


€ FOR THE EXPERIMENTER WITH TASTE FOR "STATE OF THE ART" PRODUCTS 
€ COMPLETE SPECIFICATIONS ARE PRINTED ON THE BACK OF EACH TECHNOLOGY KIT 


FTK0020 FTK0020 FTK0106 

SOLID 5 STATE Ы 

TECHNOLOGY KIT 
automobile clock 


тағами кұ 


РМ ЕТК0020 


SOLID STATE 


TECHNOLOGY 


FAIRCHILD 


de Салам 
Forman Peas Curent 1 0 не potter rn 
[А 


PIN CONNECTIONS 


TEN RED LEO LAMPS 


TECHNOLOGY BY 


asom | camaos 


TYPICAL APPUGATIUN 


FAIRCHILD es rae 


4001 MIRANDA AVENUE* PALO ALTO, СА 94304 


CARD FRONT CARD BACK CARD FRONT 
DIGITS PHOTO ARRAYS 
ЕТК0001 0.5” High Common Cathode Digit $1.00 ЕТК0040 9-Element Tape Reader Array 16.00 
ЕТК0002 0.5” High Common Anode Digit 1.00 ЕТК0041 12-Element Card Reader Array 24.00 
ЕТК0003 357” High Common Cathode Digit 75 ЕТК0042 Reflective Opto Coupler 4.00 
FTK0004 0.8” High Common Cathode Digit 2.00 COUPLERS 
ЕТКООО5 0.8” High Common Anode Digit 2.00 FTKO050 4G | IU ке сыс 0 eami 158 
2 eneral Purpose Opto Couplers à 
0.8" HIGH DISPLAY ARRAYS ЕТК0051 Darlington Opto Coupler 1.00 
ЕТК0010 12 Hour, 3% Digit Clock Display 7.00 MOS CLOCK CIRCUITS 
ЕТК0011 24 Hour, 4 Digit Clock Display 8.00 одоб Биа Calendar Circi РА 
igital Clock/Calendar Circuit à 
LED LAMPS. (FCM7001) 
ЕТК0020 10 Red LED Lamps 1.00 ЕТК0401 Digital Clock/Calendar with BCD 7.00 
ЕТК0021 5 Mixed Colored LED Lamps 1.00 Outputs (FCM7002) 
ЕТКОО22 10 LED Mounting Clips 1.00 FTK0402 Direct Drive Digital Clock Circuit 5.00 
FTK0023 5 Three Piece LED Mounting Adapters 1.00 with AC Output (FCM3817A) 
PHOTO TRANSISTORS FTK0403 Direct Drive Digital Clock Circuit 5.00 
лен EC E with DC Output (FCM3817D) 
FTK0030 5 Flat Lens Photo Transistors 1.00 FTK0405 Direct Drive Digital Clock/Calendar 6.00 
ЕТК0031 5 Round Lens Photo Transistors 1.00 Circuit (FCM7015) 
ЕТК0032 3 Flat Lens Photo Darlingtons 1.00 KITS 
ЕТК0033 3 Round Lens Photo Darlingtons 1.00 ЕТК0106 Automobile Clock Kit 40.00 
@ THESE PRODUCTS ARE PACKAGED FOR OUT- € DEALER'S AND WHOLESALER'S INQUIRIES 
STANDING WALL DISPLAY APPEARANCE INVITED —PRICE LIST AVAILABLE. 
Ен Тат ы ud 
e FULL шаг! LT mi T PRODUCT LINE eBUY WITH PRIDE THE PRODUCTS BUILT BY 
ыны сағағы ë 
ТО FOLLOW THE INDUSTRY’S LEADER — FAIRCHILD 
a маме 


Р 1021 HOWARD STREET 
Satisfaction Guaranteed. $5.00 Min. Order. U.S. Funds. 
California Residents — Add 6% Sales Tax GA Ж & 6 SAN CARLOS, СА 94070 


Send а 24c Stamp (postage) for a FREE 1977 Catalog. PHONE ORDERS — (415) 592-8097 
NOW OPEN SATURDAYS 


Photo 2: The Astral 2000 computer is $995 partially assembled ог $1250 
fully assembled and tested, Additional fully assembled 8 K RAM boards 
are $245 each and the 8 К EROM board is $59.95, The VID-80 video ter- 
minal is $189.95 in kit form or $245 fully assembled and tested. ГО tape 
interface units are $49.95 each, The software package includes Astral BASIC 
on magnetic tape cassette or paper tape (specify), complete documentation 
and a free one year subscription to the Astral Newsletter, a// for $35. The 
Astral 2000 is available from M&R Enterprises, POB 61011, Sunnyvale 
CA 94088. 


purposes of imagery and showing off a 
classical "computer." The toggle switches 
and lamps don't really control a thing 
directly, since they lead directly to a group 
of PIA ports, as do the other "front panel” 
features such as the system's real time clock. 

The “turn key” effect is achieved by two 
subsystems of the central processor board 
design and an optional VID-80 video display 
terminal board. The processor board con- 
tains the key to turn key operation, a2 K 
byte ROM monitor. This monitor program 
can be used in one of two modes: lt can 
drive the VID-80 terminal interface board, 
or a standard serial line interface with both 
20 mA current loop (Teletype compatible) 
and EIA RS-232C compatible drivers for 
typical commercial terminals. The serial ter- 
minal interface also includes control lines for 
auxiliary functions such as reader and punch 
control. 

The logical features of the Astral 2000's 
monitor program will prove quite useful. 
The input of the monitor is buffered so that 
commands can be repeated simply by enter- 
ing an ASCII space code from the keyboard. 
In the context of a command like the one 
which dumps “n” bytes, this can be a saver 
of keystrokes: once “ТҮРЕ 8" has been 
entered, additional 8 byte groups of data can 
be dumped in sequence by simply entering a 
space. The monitor also includes machine 
language debugging facilities to aid the low 
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level language hacker. These debugging facili- 
ties include patching and displaying memory 
contents, insertion of break points, stepping 
through break points, etc. The Astral 2000 
monitor also has larger scale data manipula- 
tion facilities which include memory check 
sum calculation, ‘block insert" for tempora- 
ry program patches, a command which can 
be used to calculate relative branch offsets, 
and patch points for the software interrupt, 
nonmaskable interrupt or maskable interrupt 
requirements of applications systems and 
programs. 


High Level Language Facilities 


A major concern of most users is the need 
for high level language facility. In the Astral 
2000 case, one of the strong points in the 
descriptive literature is its 8 K extended 
BASIC implementation. This is part of a 
standard $35 software package which is 
available to the purchaser of the system, The 
descriptive literature of Astral BASIC im- 
plies that it will prove quite useful, whether 
the application is business processing, games 
hacking, or a host of other small computer 
uses, Here is a summary list of the points 
found in the Astral BASIC which supple- 
ment the usual features of any good ex- 
tended BASIC. 


* Floating point arithmetic with user 
selectable precisions of 6, 9, 13 or 16 
decimal digits. (Trade execution time 
off against precision of calculation.) 

* A unique DO statement references 
groups of statements by number to 
provide a simple form of subroutine 
call not usually found in BASIC, 

* Full statement trace facility. 

* Variable length character strings of 
unlimited (ie: 2**16) length. 

° Substring search function for charac- 
ter strings. 

* Complete line oriented editing facili- 
ty including a renumbering facility 
which alters all GO TOs. 

* Formatted output with PRINT US- 
ING, an essential for practical applica- 
tions programming. 


Miscellaneous 


Rounding out the details of the Astral 
2000, the standard version includes an audio 
interface for magnetic tape recording, a real 
time clock based upon a standard 24 hour 
clock chip accessed through PIAs and level 
shifters, and a centralized power supply with 
5 V at 12 A. Prices for several of the 
component modules are printed in the cap- 


tion for photo 2.8 
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7400 12% 
7402 14 
7403 14% 
7404 16% 
7407 .20 
7410 12% 
7420 12% 
7427 25 
7438 20 
A2: 
7441 .65 ж 
7445 .45 
7447 75 
7450 14 
7451 14% 
7473 22 
7474 23 
7480 40% 
7493 -50 
7495 49 
74107 .29 
74109 .30 
74116 1.50 
74123 45: 
74141 .80 ж 
74145 75 
74150 60% 
74151 .60 


Order Minimum $10.00. Add $1.00 shipping and handling charge per order. California residents add 6° sales 


* SPECIAL PRICES * 


74152 
74155 
74157 
74160 
74161 


74163 
74165 
74173 
74174 
74175 
74177 
74180 
74181 


74192 
74193 
74194 
74198 
9602 
9300 
9312 


SCHOTTKY 


74S01 
74502 
74537 
74538 
74585 
745113 
745139 
745140 
745153 
745172 
745174 
745175 
745181 
745197 
745257 


.90 


.25 
.25 
40 
60 
2.00 
80 
1.50 
-50 
2.50 
4.50 
2.05 
2.05 є 
4.50 
2.20 
1.50 


tax. All orders shipped First Class within 24 hours. 


HIGH SPEED 
74H00 
74H01 
74H04 
74H10 
74H11 
74H40 
74H51 
74H52 
74H74 
74H103 
74H106 


LOW POWER 
SCHOTTKY 


74LS00 
74LS02 
74LS08 
741510 
74LS27 
74LS73 
741.575 
7415151 
7415153 
7415157 
7415161 
7415163 
7415164 
7415174 
7415175 
7415193 
7415221 
7415251 
7415253 
74LS257 
74LS258 


CMOS 


4001 
4002 
4006 


1.10 
1.10 
1.10 
1.50 Ж 
1.50 
1.50 
1.10 
1.50 
1.50 
1.50 ж 
1.50 
1.50 
1.50 
1.50 


164: 
16 
-90 


4007 
4008 
4011 
4012 
4013 
4015 
4016 
4019 
4020 
4021 
4023 
4024 
4025 
4027 
4028 
4030 
4040 
4042 
4043 
4044 
4049 
4050 
4066 
4068 
4069 
4071 
4073 
4075 
4516 
4528 
4585 


LINEARS 


МЕ536Т 
NE555V 
NE556A 
1456V 
1458V 
566V 
567V 
540L 


World’s Lowest 
IC Prices 


Order the famous lasis 6 volume Programmed Learning Course "Microcomputer Design is a Snap" for 
$99.50 and receive a special $10.00 credit on any group of IC's. 


Satisfaction 100% guaranteed. 


ELTRON 


C.O.D. Orders: Phone (day or night) 408/354-1448 


PO BOX 2542 


Free monthly catalog—Just send us your name and address 
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Sunnyvale, СА 94087 


BUTE 


— Designing With TTL Integrated Circuits $24 


Still More 
BYTE's 
Books 


* DESIGNING WITH TTL INTE- 
GRATED CIRCUITS by the Components 
Group, Texas Instruments Inc. Edited by 
Robert L Morris and John R Miller. 


People often ask questions like "Where 
do | get basic information on hardware 
design?" One answer is in "Designing With 
TTL Integrated Circuits." 

This book, published by McGraw Hill in 
1971, is a fundamental starting point for 
any person designing peripherals and custom 
logic employing TTL. integrated circuits. 
While its publication date precludes any 
reference to the later additions to the TTL 
7400 series of components found in the 
Data Books, it is nevertheless the source of a 
wealth of ideas on TTL integrated circuits 
and design of logic with this family of 
circuits. 

What is fanout? You may have heard this 
term mentioned at computer club meetings 
or in advertisements for circuitry, or in 
articles їп BYTE. You can find out 
background information on the calculation 
of fanouts by reading the chapter on Circuit 
Analysis and Characteristics of Series 54/74. 

Worried about noise, shielding, ground- 
ing, decoupling, cross talk and transmission 
line effect? (Or, more properly, did you 
know you should worry about these effects 
in certain circumstances?) Find out about 
general precautions and background infor- 
mation by reading the chapter on Noise 
Considerations. 


The chapter оп Combinatorial Logis 


—— Microcomputer Design $25 
Send to: Name 


Address 

Ci State Zi 
өз П Check enclosed 

П Bill MC Мо. Exp. Date 

П Bill BA No. Exp. Date 


BANKAMERICARI. 


Please add 25 cents for each book, for Please allow six weeks for delivery. 


l postage and handling. 


PETERBOROUGH, NH 03458 


Signature 


Design gives 53 pages of background 
information on Boolean algebra and practi- 
cal representations of logic in the form of 
SSI gates. The chapter includes a description 
of Karnaugh mapping techniques and the 
minimization of logic. From combinatorial 
design, the book progresses into Flip Flops, 
including background information on the 
workings of these devices, and fairly 
detailed descriptions of the uses and 
applications of these devices including 
synchronization of asynchronous signals, 
shift registers, flip flop one shots, etc. Then 
the book returns to static combinatorial 
logic with its description of the Decoders 
available in the 7400 line as it stood in 
1970-1971. 

A chapter on Arithmetic Elements gives 
fundamental descriptions of binary arithme- 
tic, diagrams of the basic gate configurations 
for combinatorial logic adders, and a section 
on number representations for use іп 
computers. Much of the material in this 
section is dated, due to the fact that the 
later 74181 series of multiple function 
arithmetic units had not yet appeared when 
the book was written. But for a background 
on arithmetic operations implemented with 
the simpler 7483 circuits, this chapter is 
ideal. A chapter on Counters and a chapter 
on Shift Registers complete the detail logic 
sections, The book is closed out by a 
chapter on miscellaneous Other Applica- 
tions including a simple binary multiplier, a 
12 hour digital clock and a modulo-360 
adder. 
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The most important use of this book is its 
value as an introduction to TTL logic. By 
reading and studying it, you will, begin to 
understand the ways in which SSI and М5! 
TTL gates can be utilized in your own 
experimental logic designs. After studying 
this text, you should be able to make much 
more sense out of the technical information 
summaries typically published as specifica- 
tions sheets and data catalogs. 

Order your copy today from BYTE's 
Books, $24. 


®MICROCOMPUTER DESIGN by Don- 
ald P Martin, Martin Research, Edited and 
Published by Кету S Berland, Martin 
Research. 


Purchase your copy of the definitive 
source for circuitry and hardware design 
information on the 8008 and 8080 com- 
puters today. 

Even Intel, the originator of the micro- 
processor revolution, is hard put to compete 
with the wealth of information found in 
Martin Research's new second edition of 
Microcomputer Design. This is the book 
which was originally published as an 
expensive (but quite practical) engineering 
report in loose leaf form, at about the time 
the microprocessor technology was first 
catching on in the form of the 8008. This 
388 page second edition of the manual is 
loaded with detailed information on how to 
build and use computers based on the 8008 
and 8080. 

But even if you do not intend to use the 
8008 or 8080, the practical pointers on 
digital logic design, peripherals and applica- 
tions of hardware techniques will more than 
justify the new low price of $25 for this 
handbook, Microcomputer Design is a must 
for 8008 owners and 8080 owners who 
want to truly understand how their 
processors process, 

Microcomputer Design is complete with 
numerous illustrations, tables and diagrams, 
plus reprints of the specifications sheets for 
the intel processors. There are numerous 
practical examples of circuitry and many 
complete computer designs ranging from 
“minimal microcomputers” to a full blown 
8080 processor. 

Order your 
BYTE's Books 


copy today, $25 from 


DELTA ELECTRONICS 


POST OFFICE BOX 2 AMESBURY, MASS. 01913 PHONE (617)388-4705 
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CORE MEMORY BOARD 


This memory board has 2 non-volatile magnetic core 
memory planes, each plane consisting of a 26 x 52 
bit array; Total capacity is 2704 bits (1352x2). Four 
could be used to make a 1352 word memory, 8 bits 
wide. Because of its ability to retain data when power 
is removed, core memory is uniquely suited for boot- 
strap loaders, program development memore space, 
and whenever power failure is a major concern, such 
as in a security systems, 2 3/4 x 4 С inches; 
STOCK NO. 5446B $2.50 4/9.00 


GAINT NIXIE TUBE ASSEMBLY 
2 burroughs B7971 15 segment 
Alpha-Numerical tubes, 2.50 inch 
characters, 2 sockets mounted on 
driver board with 33 transistors. 
Perfect for large clocks and Alpha- 
Numerical displays. Data supptiee 
8 inches x 10 3/4 inches x 2 1/2 


— & CAN 
0068 


inches, 3 lbs, Mi Hedge қ ' 

STOCK NO. 6001 В $6.95 2/12.00 AA ALKALINE BATTERIES 

NIXIE TUBE AA 1.5у Penlight batteries are great for 

Left side display low-voltage ea equipment and alike. Also advantages GRIGSBY BARTON 
ӘЧЕ Kora ды 9 Dn et for the hobbiests, All batteries are 

sockets, 0.8 inch mounting guaranteed before shipment. Most all DRY REED RELAY 
pe камы ER 5/ 1.00 AA batteries are sold competitively for 

A Tiseament'inesndegcent readout two (2) for $1.59.. BUT DELTAS:......... 

tube. (5/8 characters) Requires a STOCK NO. 5443 B 4/$1.00... 


9 pin Novar socket (supplied). It is 
а 4,5 volt 24 mA per segment. Сап 
be filtered to any color. Data sup- 


lied. 
BTOCK МО. 5207 B $2.75 4/10.00 8/18.00 


TUNG-SOL DIGIVAC READOUT 
А 7 segment fluorescent read out 
tube (,36х.57 character) qug a 
9 алал socket(supplied) 12 to 
50 volts per segment. Readout, green 


Туре G821 А SPST-14 pin, 24vdc 2150 ohms. Sheilded 
diode non-electrostatic sheild. They will fit standard 14- 
pin receptacles, they are designed for direct printed cir- 
cuit board mounting where desirable. Internal clamp in 
circuit Bd mounting where it is desirable, Internal clamp 
diodes for protection of drivers by suppressing back EMF 
There is data available. 


STOCK NO.. 1003 B $1.75 2/ 3.00 


STOCK NO. 5140 В ‘$2.65 2/5.00 6/14.00 CRYSTAL ES 
SPERRY INFORMATION DISPLAY "Exi mas noe : қ 
Direct interfacing with MOS/LS. 9 4,000,000 MHz CR-184/U. Crystal Half інен Switches designed with only {уо moving paste. 
digits, includes point and comma. сап is .75x.75. The pins are .05 thk Mount, кесу on, Printed Circuit Boards or panels, Р 
Characters .25 inches intended for Е j itive detent, 36° indexing stops. 250 MA at 28vde. 
multiplex operation, complete data and the mounting spacing is .50. switching positions per position-contact resistance ы 
supplied ы The crystal pin spacing is standard ohm max. Operation temperature -65° C to - 150°C 
STOCK NO. 5275 B $2.95 2/ 5.00 : i i 

TOCK Ё 1001 B $3. .00 87-22-25 Knob Adjust 0.555 dia x 0.280 high 
BURROUGHS DISPLAYS | ыссы ы Toe oa 2 pole - y osition. us 
12 digit panel display contains comma's STOCK NO. 1004 $2.00 417.00 
and periosd. Characters 25 inches у CRYSTAL HOLDER Passa d du 
ideal for any device requiring multip -12- crew driver 
digits. Compatable with DTL‘ TTL and STOCK NO. 9169 B 561.00 Adjus 0.500 dia x 0.190 high 
C MOS. Neon glow discharge, orange Single pole 10 position 
in color. Socket and data supplied 
STOCK NO. 5220 B $2.95  2/5.00 STOCK NO. 1005B $1.75 2/ 3.00 


SEND FOR OUR LATEST FREE CATALOG, WE WELCOME MASTER CHARGE & BANK AMERICARD. WE MUST HAVE ALL THE 
NUMBERS ON THE CARD FOR PROCESSING, PLEASE INCLUDE SUFFICIENT POSTAGE (2 LBS M IN); EXCESS WILL BE REFUNDED, 
MINIMUM ORDER ss. 


7400М тт 


‘SN7459A > 
‘SN7460N SN7A1S4N" 1. 
SN7470N SN74155N 
SN7472N SN74156N 
SN74157N 


5Н7АТЗНУ 
SN7474N SN74160N 
SN74161N 


SN7475N* N 
SN74163N 


SNTA76N" 
SN7479N* SN74164N 
SN7480N SN74165N 
5874828 SN74166N 
SN7483N 58741678 
SN7485N SN74170N 
SN7486N SN74172N 
5874888 58741738 
SN7489N. SN74174N 
SN7490N SN74175N 
SN7491N SN74176N 
Sue НЕНЫ 
SN7494N SN74181N 
SN7495N SN74182N 
5874968 SN74184N 
SN74185N 


SN7497N* 
SN74100N* SN74166N* 
SN74187N 


SNT4107N 

SN74121N* SN74188N 

SNT4122N. SN74190N 

SN74123N' SN74191N 
SN74192N* 


SN74125N 
SN74126N SN74193N* 
SN74184N 


SN74132N 

SN74136N SN74195N 

Sat SN 

SN74143N* 5М741988 
SN74199N 


SN74144N* 

5М741458 SN74200N 

SN74147N SN74279N* 

SN74148N SN74251N 
SN74284N 


SN74150N 
SN74151N SN74285N 
SN743867N 


SN7400N" 
SN7AQ1N 
SN7402N 
SN7403N 
SN7404N* 
SN7405N 
SN7AQ6N 
SN7407N 
SN7408N 
SN7409N 
SN7410N* 
SN7411N 
SN7412N 
SN7413N 
SN7414N 
SN74168 
SN7417N 
SN7420N 
SN7421N 
5N7422N* 
5974238 
SN7425N 
SN7A26N 
SN7427N 
5874298 
SN7430N 
5874328 
SN7437N 
SN7438N 
SN7439N 
SN7440N 
SN7441N 
SN7442N 
SN7A43N 
SN7444N 
SN7445N 
SN7446N 
SN7A47N* 
SN7449N 
SN7450N 
SN7451N 
SN7453N 
SN7454N 
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Р SN74153N 
MANY OTHERS AVAILABLE ON REQUEST 
20% Discount for 100 Combined 7400's 


7ACOAN 
74CON 
74C20N 
74C30N 
TaCA2N 
TAC73N 
74674 
74C90N 
7AC95N 
7461078 
7ACIS! 
740154 
74С187 
74С160 
74С161 
74C163 
7416: 
740173 
74С193 
746195 
MC4044* 
MCMOI16* 


ИЛЕ 
LMI351N 
LMTATAN 
LMMSBC 
LM1496N 
LMI556V 
LM2111N 
LN2901N 
LM3065N 
LM3900N 
LM3905N 
1м3909* 
LM5556N 
MC5558V 
LM7525N 
\М75835Н 

80388^ 

475450 

75451CN 

75452CN 

7545208 

75454CN 

75491CN 

75492CN 

75404CN 

АСА LINEAR 

CA3013 215 
САЗ022 256 
CA3035 248 
САЗ039 125 
CA3046 130 
CA3059 3.25 
CA3080 

САЗ080 

CA30B1 

САЗ082 

Сазйвз 

СА2086 

CA3089 

CA3091 

CA3123 

CA3130 

СаЗ140 

САЗ600 

RC4194 

RC4185 


Т Т L 74LS139 
7445151 
745153 
1415157 
7415162 
7315163 
2405161 
741515 
745181 
7415190 
7415191 
741519 
7415193 
71519: 
7415195 


04035 
CD4040 
C04042 
CD4044 
€D4046 
CD4047 
CD4049 
04050 
C0405! 
С04053 
CD4060 
С04066 
С04069 
С0407: 
CD4081 
С04511 
С04518 
CD4566 
74COON 
746028 


LMIOIH 
LM301CN 
LM302H 
LM304H 
LM30SH 
LM307CN 
LM308H 
LM3OBCN 
LM309H 
UM309K 
LM3I0CN 
LM3TIH 
ШАШ 
1мэтвсм 
LM319N 
LM320K-5 
LM320K-5 2 
LM320K-12 
LM320K-15 
LM320T-5* 
LN320T-5.2 
LM320T-8" 
LM320T-12* 
LM320T-15 
(М320Т-18% 
1м320Т-24 
1323-5" 
1M324N 
1M339N 
LN340K-5 
1М340К-6 
LM340K-8 
LM340K-12 
LM340K-15 
LM340K-18 
LM340K-24 
1м3407-5 
(3407-6 
UM340T-8" 
\м3407-12 
LM340T-15 
LM340T-18" 
LM340T-24 
марон 
LM3bICN 
74.500 
741502 
741503 
741504 
741505 
741508 
74510 
74613 
141514 
741520 
741526 
741527 
74528 
741530 
741532 
141540 
141551 
730555 
141573 


741500 


741574 
741575 
741576 
741583 
741585 
751586 
741590 
741592 
731593 
141595 
241596 
7415107 
7415109 
7415112 7415257 
7415132 7ALS260 
7415136 5 7418279 
7415138 7115670 


DATA HANDBOOKS 
7400 Pin-out & Description ої 5400/7400 ICS $2.95 
CMOS Pin-out & Description of 4000 Series ICS $2.95 
Linear Pin-out & Functional Description $2.95 
ALL THREE HANDBOOKS S6.95 


100 PER STRIP MOLEX PINS 


Intended for use as an inexpensive substitule for IC 
sockets. Also perlect for use as board connectors 
and in subassembties. 


SPECIAL — 100/1.49 — 1000/12.00 


SINGLE 
GAME 


4 GAMES 
IN ONE 


PONG $55.00 
SUPER PONG $79.95 


GAMES INCLUDED IN SUPER PONG ARE: 

e PONG e CATCH 

e SUPER PONG ө HANDBALL 
FEATURES OF PONG ANDSUPER PONG 


incremental speed оп volleys increases excitement 

Playing heid adjusts to any size screen 

Game appears in color oc in black & white, depending an television set 

Unmstakable PONG sound accompanies each volley 

Digual scoring flashes on the screen between each point 

2 різует challenge or Solitaire 

Hooks up simply to any model television set. the screen aclually becomes the playing field 
Engish and other lechaiques can br used ta make any member of the family a Pong champion. 
Baltery operated by 4 size D Нати balteries included with the Unit 


AC Adaptor (Eliminates Batteries) 959.95 


PONG 


ica Wm DISCRETE LEDS 


XC209Gre 


XC209 Y allow 7/ 
XC209O0range 4/ 
Moa 
.185" dia. 
XC526Red  10/$1 


XC526Green a 


200” dia. 
XC22Red 10/51 
XC22Green 4/$1 
ХС52б6Үейоу 4/51 XC556Yellow 7/! 
ХС526Огапде 4/$1 XC5560range Е red LED 
XC526Clear 451 ХС556С!еаг 6/$1 


DISPLAY LEDS 


XC220range 4/81 


SSL-22RT 4/51 
POLARITY 


Common Anode-orange 
Common Cathode-orange 
Common Anode-Red 
Common Anode-red. 
Common Anode 
Common Cathode 
Common Anode 
Common Cathode 
Common Cathode 
Common Cathode 
Common Cathode 
Common Anode 


90” dia. 
1Red 10/51 
1Grean 4/81 
1Yellow 4/51 
1Orange 4/51 


е —^— 


.200"' dia. 085” dia. 


XC556Red 10/: 
XC556Green 7/: ens Micro 


1 
1 
1 
1 
1 


хс1 
xci 
XC1 
xc1 


MAN 4 MAN 7 


POLARITY TYPE 
Common Anode MAN 3620 
5 x7 Dot Matrix MAN 3640 
Common Cathode MAN 4710 
Common Cathode 0701 
Common Anode 04707 
Common Anode-green DL 728 
Common Anode-yellow DL 747 
Common Anode-green 

Common Anode-red 

Common Anoda 

Common Cathode 

Common Anode-yeliow 

Common Cathode-yeliow 
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25-49 


40 pin 


ASST, 1 5 ег. 1/4 WATT 5% 50РС5. 


ASST, 2 без. 1/4 WATT 5% SOPCS. 


1/4 WATT 8% — SÜPCS. 


1/4 WATT 5% 50 PCS. 


1/4 WATT 5% SOPCS. 


1/4 WATT 5% 52РС5. 


1/4 WATT 5% 
$10.95 ва, 
500.995 0275 ға 


50РС$. 


E 


500 


8 SOLDERTAIL STANDARD (ТІМ) 
um liu 24 pin 
| 40 pin 
28 pin 
50 PCS. RESISTOR ASSORTMENTS $1.75 РЕВ ASST. 
680HM 82 0HM 1000НМ 120 0НМ 150 OHM 
ASST. 3 Sea, 1.2K 15K 18K 22K 27K 
22K 27K 33K 39K 4T 
ASST. 6 Ses. 390K WOK 560K 680K 820K 
ASSI: 8R All Seven Resistor Assortment 
e Resistance Tolerance + 20% $ 89 
STANDARD RESISTANCE VALUES ° 
1000 5000 
Satisfaction Guaranteed. $5.00 Min. Order. U.S. Funds. 


ES 10 
SOLDERTAIL STANDARD (GOLD) 
28 pin 
5 36 pin 
WIRE WRAP SOCKETS (GOLD) LEVEL #3 
bc Д 24 pin 
Ел 36 ріп 
40 pin 
100HM 120HM 150нм 180HM 22 CHM 
270HM 330НМ 390HM 470HM 56 HM 
180 OHM 220 ОНМ 270 ОНМ 330 0НМ 390 OHM 
470 OHM 560 OHM 680 OHM 820 OHM 1K 
3.3K 3.9K 47k 5.6K 6 8k 
ASST. 4 Sea. B2K 10K ж 18K 18K 
ASST. 5 Sea, 56K 68k 82k 100k 120K 
150K 180K 220K 270K 330K 
1M 12M 15M там 22м 
ASST. 7 Sea, 27M 33M 39м 47M 5.8M 
30-95 PCS Qi ca 100. 495 РС5 03 єл 
SINGLE TURN 9%” CERMET POTENTIOMETER 
e High Power —0.5 Watt at 70°C 
e Wide Operating Temp. Range —55°C ta + 125°С 
1K 2K 5K 10K 20K 50K 100K 200K 500K 1 MEG 
АП Advertised Prices Good For This Month Only — November 
California Residents — Add 6% Sales Tax — Data Sheets 25e each 
Send а 240 Stamp (postage) for a Free 1977 Catalog 


1021 HOWARD AVE., SAN CARLOS, CA. 94070 
PHONE ORDERS WELCOME — - (415) 592-8097 


MINIATURE 
TOGGLE 


Description, 
EM A Single Poie 10 Posuign 7 25250 
EE 
ЗЕЙ 
3821 


Ее 
E! 


SPOT - SERIES РӘ, РӘ! 


Mamtained Action Seoteh 
тан to Мәке Contant Аға 
pn То Retarve Arnon 


PB-123 $1.75 
PB-126 $1.75 


$ AMP RATINGS. 


THUMBWHEEL SWITCHES 


„инине SWITCH ОУ Ordering: Order deprad steh ot switches 


Price and add necessary occessones dor your 
particular application: 


tary Action Switch 
Nerrmally Open or Normally 
Сони Lhar N C cecus use 
Termini 2 & 1. tor NO 2 
Аз. VC nd NO. 1243 


ror 300 
WFowtian BCD оту | 250 
300 SF- Front boun SA- Rese Moun 


SERIES SF Front Moum Assembly SERIES SR Rear Mount Ашен, 


МІН нш 


, ACCESSORIES ACCESSORIES 
Ti PartNo Description __ 
SREP T Eng Plates tpar} | 
SRDP T бенен Pime teagh) = 
SABE , Blank Body leach) | 
SR-HB ^ Halt Body (кеп) 


rin Plate (Рант 
unter Plate (each) 
Blank Body teach) 


SFH8 | Mail Body leach) 


These switches feature seven SPST slide switches in а 
molded dip They are sdeally suited for microprocessor 
appiicahons $1.95 


4/$1.00 
@CLIPLITE mounts from the front 


ux 
of the Panel іп а .250 hole on 3/8” 
centers, Panel thickness from 1/16" to 1/8”, 
@CLIPLITE equalizes anu increases the brightness of 
commonly used wide beam LEDS. 
@CLIPLITE is то be used with XC556 LEDS. 
®Spacify colors-red, green, amber, or yellow when 
ordering. 


ZENERS—DIODES—RECTIFIERS 
юзу м т йз w 


CLIPLITE !! 
NEW LED 
MOUNTING SYSTEM 


1№4005* 600 PIV 
300v 4100 — 1N4006* 800 PIV 
soon — 2100 — 184007" 1000 PIV 
100m 1N3800 5 
400m 184148 
400m лы 
300m $ 144305 
500т 184734 
500m 184735 
500m 184736 
500m 184738 
aon 184742 
тт 144744 
10m 1М1182 50 РМ 35 AMP 
1 АМР 1N1184 100 РМ 35 АМР 
100 PIV 1 АМР 101185 150 PIV 35 АМР 
200 PIV 1 AMP INT186 200 РМ 45 АМР 
400 PIV 1 АМР 11188 200 Piy 15 ANP 


SCR AND FW BRIDGE RECTIFIERS 
C36D 15A @ 400V 
савм 35А @ 200V КА 
282328 ТБА @ 20% SCR 
25A @ SQV FW BRIDGE REC 
25M 200v FW BRIDGE REC 


TRANSISTORS 


39100 
481 0U 
25100 
551 00 
551 0 
561 00 
551 0 


ТАМР 
ТАМР 
4 АМР 


00 
18100 
#0 
450) 
иш 
ШТ 
кен 


ВЧ 
эф 
ИШ 
ШИЛ 
n 
5sra) 
7 
ре 
1.75ea. 


5 
23901 
282004. 
28320, 


CAPACITOR 


50 VOLT CERAMIC 
DISC CAPACITORS 
10-49 50-100 
10 pt 4 04 
22 pt E 04 
47 pl 2 К 
100 pf 4 
220 pt E u“ 
470 pl 45 б 095 
100 VOLT MYLAR нн CAPACITORS: 
т! K E 92204 
0022 b 07 — .047mf 
-0047ml В o imt 
„От В 10 07 ?2mf 3 
+20% ай TANTALUMS (SOLID) салото 
ARSV E B 1.5/35У 
.15/35У 2.2/25У 
-22/35V 3.3/25V 
-33/35V. 4.71125У 
6.8/25V 
10/25V 
8 [2 Л 15/25] d 50 
MINIATURE ALUMINUM ELECTROLYTIC CAPACITORS 
Axial Lead Radial Lead 


2200/16V 


C77 CRYSTALS [a 


THESE FREQUENCIES ONLY 
Frequancy Case/Styis Pri ee 


BP — 


СҮТА 1.000 MHz HC33/U $5.95 
CY2A 2.000 MHz HC33/U $5.95 
CY3A 4.000 MHz HC18/U $4.95 
CY7A 5.000 MHz HC18/U $4.95 
CY12A 10.000 MHz HC18/U $4.95 
CY14A 14,31818 MHz HC18U $4.95 
CY19A 18.000 MHz HC18/U $4.95 
CY22A 20.000 MHz HC18/U $4.95 
СҮЗОВ 32.000 MHz HC18/U 54,95 


CLOCK CHIPS — CALCULATOR CHIPS 


ММ5309 6 Digit, BCD Outputs, Reset PIN $9.95 
ММ5311 6 Digit, 800 Outputs, 12 or 24 Hour 4.95 
ММ5312 4 Digit, BCD Outputs, 1 PPS Output 4.95 
MM5314 6 Digit. 12 or 24 Hour, 50 0” 60 Hz 4.95 
MM5316 4 Digit, Alarm, 1PPS Output 6.95 
ММ5318 video Clock Chip. For Use With ММ5841 9.95 
Cr7001 8 Digit, Calander, Alarm, 12 or 24 Hour 5.95 
CALCULATOR CHIPS 
MM5725 8 Озди, Four Function, Less Decimal $2.95 
ММ5738 8001. SFunction + =, х.-,% 295 
M5739 8 Digit. 4 Function, Floating Decimat 2.95 
CT5030 12 Digit. 4 Function 814% 7.95 
MISC. MOS 
MM5320 TV Camera Sync. Generator $19.95 
MM5330 4% Digit DVM Chip 9.95 
ММ5369 80 Hz Timebase Circuit From 3,58 MHz 3.95 
ММ5841 Video Generator tor ММ5318 18.00 
М0140847 7 Bit Digital to Analog Converter 9.95 
Мк5007 4 Decade Counter with Latches 10 95 
{01010111 3% Digit DVM Chip Set 25 00 


95H90 100 MHz = 10 Counter For Prescaiers 


This 0-2 МОС .05 per cent digital voltmeter features the Motorola 37 digit 
DVM chip set, It has a .4” LED display and operates from a single +5V 
power supply. The unit is provided complete with an injection molded black 
plastic case complete with Bezel. An optional power supply is available 
which lits into the same case as the 0-2V DVM allowing 117 VAC operation. 


A. 0-2V DVM with Case 
B. 5V Power Supply 


“ 
“ “ 3 
Vector Wiring Репсі P173 consists of a hand held featherweight (under one ounce) 
1901 which 15 used tc guide and wrap insulated wire led off а self-contaned replaceable 
bobbin onto component leads or lermunais installed on pre-punched "P Pattern 


Vectorbord Connections between the wrapped wire and component leads pads or 
terminals are made dy soldenng Complete with 250 FT of ted wire. $7 95 


REPLACEMENT WIRE — BOBBINS FOR WIRING PENCIL 


W36-3-A-Pkg. 3 250 ft 36 AWG GREEN $1.95 
W36-3-B-Pkg. 3 250 ft. 36 AWG RED $1.95 
W36-3-C-Pkg. 3 250 ft. 36 AWG CLEAR $1.95 
W36-3-D-Pkq 3 250 ft. 36 AWG BLUE $1.95 


1/16 VECTOR BOARD 


D 1^ Hole Spacing P-Paltern 
Part ^ ЫШ 


Price 


PHENOLIC б4Р-Ы1 0Е2ХХХР + 650 172 154 
16944 QXXKP 1% 1700 36 332 

EPOXY барда 062 150 650 207 1% 
GLASS BAPA 062 150 850 2% 21 
169P43 062 250 1700 501 453 

169РВ1 062. 850 1700 923 826 

Fere LASS 169Р44 06901 450 100 68 612 


бирер дын 


Mk HEAT SINKS ш 


205-CB Beryllium Copper Heat Sink with Black Finish for TO-5 25 
291-.36H Aluminum Heat Sink for 70-220 Transistors & Regulators .25 
680-.75A — Black Anodized Aluminum Heat Sink tor 10-3 1.50 


NIBBLING TOOL 


As 


Nibbilng Tool 
Replacement Punch 


63 KEY KEYBOARD 


DIAGONAL CUTTER 


м" ki Flush Cut Fine Diagonal 


OS 


Light Blue Handle 
А97М$ 


E 


$6.95 
$3.75 Each 


58.50 ea. 


suits most applications 


$19.95 


$7.95 


HOO165 16 LINE TO FOUR BIT PARALLEL KEYBOARD ENCODER 


JOYSTICK 


These joysticks feature tour * 
potentiometers, that vary re- 
sistance proportional to the 
angle of the stick. Sturdy metal 
construction with plastics 
components only at the mova- 
ble joint. Perfect for electronic 
games and instrumentation. 


*5К Pots $6.95 
*100K Pots $7.95 


$49.95 
$14.95 


This keyboard features 63 unen- 
coded SPST keys, unattached to 
any kind of Р.С.3 А very solid 
molded plastic 13" x 4" base 


MICROPROCESSOR COMPONENTS 
8080 SUPPORT DEVICES: 


8080А 8212 В ВІТ INPUT/OUTPUT PORT FOR 8080 $595 8080 
$34.95 8216 МОМ INTERRUPT BI-DIRECTIONAL BUS DRIVER 7.95 $24.05 
5 8224 CLOCK GENERATOR AND DRIVER FOR 8080 12.95 Á 
8228 SYSTEM CONTROLLER AND BUS DRIVER FOR 8080 12.95 

CPUS RAM'S 
8008 B AIT CPU 519 95 no 256x1 5ше 5225) 
8080 Super 8008 24 95 1503 1024 x 1 Dynamic. 2 for 1.00 
8080A Super 8008 34.95 2101 256xt Stabe 5.95 || 
Ed 2102 1024х1 айс 175) 
2504 1024 Dynamic. $ 9.00 ?107 4096 x t Dynamic 9.35 
2518 Hex 32 BIT 700 2111 258x4 Static 6.35 
2519 Hex 40 BIT 400 7010 1024x1 МК05 29.85 
2524 512 Dynamic 2.43 7489 16х4 Static 2.49 
2525 1024 Dynamic 6.00 8101 256х4 Static 6.95 
2527 Dual 256 BIT 3.95 Em 256x4 5ше 6.85 
2528 Оша! $12 BIT 4.00 8599 6х4 Statie ЕЗ 
2532 Quad 80 BIT 385 9102 1024 хт ас 226 
2533 1024 Stanc 795 74200 256x1 Static 5.95 
3341 Е 6.95 93421 256 х1 Static 2.95 
7415670 16 x 4 Reg 395 MMS282 (2K x1 Dynamic E] 
UART'S PROMS 
AY-5-1013 30 Baud $5.95 1702A 2038 Famos $13.05 
ROMS 5203 2038 Famos 14 95 
2513 Char Gen $ 9.95 82523 32x8 Open С. sco f 
2516 Char. Gen 10.95 8253123 3258 Tnstate 500 
745387 1024-Bit Programmable 195 145287 1021 Static 1% 
3601 256x4 Ға 3.95 


BIPOLAR PROM SPECIAL 


Continental Specialties 
$19. 95 THE MINI- 


Proto Board 100 


40 easy assembly 
УУЗ 


Heres om coat Dig 10% capace & 
еколо ht with af (пе Guay al Ж 
OT Sockets ang the best ot the Proto BREADBOARD ы AU 
Bhatt ces, compete aoan 10 е, BUDGET KIT us MN 
The st ма вон апе serem % % ars Yy 
Inches 2 OT 395 Sucirts QNO | 
+0! 358 Bus 57р 25 way ф Б Pros Board 101 Ки * i 
риат posts 4 rubber xi. pr^ [re ж PEE 
fret аг қ iP сарост Д 
Аа iaa 58 longass wae 29.95 TE | 


Prole вып 102 Compact 12 14 
Prol бома 104, ребро 2 4 

де 3 050 зофетту 39.95 
ve ponts (45 


р? 


p 


binding posts 32:14 рит ra вао 
DIP сајаоу S? long 2 00 кинә м ^^ 
`+ 79.95 birding posts 

24-14 per DP 


COMPLETE KIT 4% 59.95 


DESIGN METE t 


CIRCUIT DESIGNER Р 
Youmiedtort HERE ITIS'CSC smse 77 
ECU desire: 10 "ир уду Duart and ЧЫ 
AMY election рим 5046 #27 AWS 


each теа 

wide Design 
weactnard Метода 
ум 


Proto Board 6 $15.95 


3 LOGIC MONITOR 


Simultaneously displays static and 
dynamic logic states of DTL, TTL. 
HTL ог CMOS ПІР ICs 

Pocket size. 


ЕГІ 
пк 
we 


SPECIAL! 


$84.95. 


QT Proto Strips 


* QT-598 
, 01-475 


OT-478 


01-355 
01-358 


DIGITAL WATCHES 


Ladies Watch 

е 6 Function 

e Bracelet Styling 
e 1 Year Guarantee 


EXELAR Mens Watch 

e 5 Function 

e Quartz Crystal 

e Black Leather Band 

e Manufacturer Guarantee 


Model 900 j 
2 Specify Gold • Specify Gold 
or Chrome or Chrome 
$69.95 $29.95 


DIGITAL QUARTZ CAR CLOCK 


Complete kit from mounting bracket of the injection molded case 
down to the three conductor power cord and all components in- 
cluding MM5314 ciock chip. Features quartz accuracy of .01%, 
six digit, .35'' high LED display. and P.C. Boards. Works on 
any 12 volt system — motorcycles, baats, vans, motorhomes, 
autos, and trucks. 


DIMENSIONS: 4%” x 4" x 2" — 12 OR 24 HOUR MODE 


Kit: $29.95 Assembled: $39.95 


DIGITAL EE KIT — 3/2 INCH DIGITS 


/ This clock features big 3*2" high digits 


for viewing in offices. audiloriums. etc. 
Each digit 15 formed by 3! bright 0.2 

LED's. The clockoperates from 117 VAC, 
has елһег 12 or 24 hr. operation The 6 
digit version is 27" х3% andthe 
"^4 digit is 18" x 3%" хт". Kits come 
complete wilh all componenis. case and 
transformer 

Specify 12 Or 24 Hr. When Ordering 


4 DIGIT KIT $49.95 4 DIGIT ASSEMBLED $59.95 
6 DIGIT KIT $69.95 6 DIGIT ASSEMBLED 579.95, 
Satisfaction Guaranteed. $5.00 Min. Order. U.S. Funds. 


California Residents — Add 6% Sales Tax — Data Sheets 25¢ each 
Send а 24c Stamp (postage) for a FREE 1977 Catalog 


1021 HOWARD AVE., SAN CARLOS, CA. 94070 
PHONE ORDERS WELCOME — (415) 592-8097 


FEATURES: 
e 8 Digit Display 


e 5 Functions conssts of addition, subtraction, mul- 
tiplication, division, percentage, with constant on 


e Black supertine grained finsh plastic cabinet 


5 FUNCTION ELECTRONIC CALCULATOR WITH 
WALLET-NOTEBOOK AND POCKET CHECKBOOK 
RADOFIN MODEL 1710 


FEATURES: 
• 8 Digit Display 
e 5 Functions consists of addition, subtraction, mul- 


This 4 digit Novus Alarm Clock 
is a very reliable and smartly 
styled unit. It provides such 
features as an alarm settable 
to any minute of the day, a 7 
minutes snooze alarm, a power 
faiture indicator, and even an 
A.M., P.M. indicator. 


e +5 Volts @ 6 Amps 
s —5 Volts @ 6 Amps 
ә 6.3Volts @ 5 Amps 


Length 8%” x Width 6%” 
x Height 4" 


CB RADIO 


aem vs 


NEW IDI ICB-630 


23-Channel Synthesized CB Transceiver 


SIZE: 6% (W) x 2" (Н) x 8% 


POWER INPUT: 5 Watis/12-Volt Max. 


POWER OUTPUT: 4 Watts RMS 


MOBILE CB ANTENNA 


| BASE LOAD - FIBERGLASS WHIP 
Mounts on Hood or Trunk Lid 


AMTEX 8 TRACK AM/FM STEREO 
FEATURES $69.95 


m8 track stereo player 

B AM/FM mpx radio 

а Advanced IC construction 

ш Dial on door and siide-bar switch type. 
© Compact — only 1-25/32" (45mm) high, 4-13/16" (122mm) deep, 6-11/16" 


(170mm) wide and 5 position adjustable shaft distance. 


ж Complete in-dash type design. 
т Easily adjustable antenna trimmer tor best performance. 


6300-1 (70 NS) 256 x 4 OPEN COLLECTOR BIPOLAR PROM (EQUIVALENT ТО 825126) $2.95 | I KRACO CAR SPEAKERS $14.95 
6301-1 (70 NS) 256 x 4 TRI STATE BIPOLAR PROM (EQUIVALENT TO 825129) j Flush Mount 10 Oz. Mag./ ohm Model SST-101F 


RADOFIN MODEL BP 


$8.95 


all functions, with fuii floating decimal point 


e Power source is 1 piece 9V DC Battery 006Р, 


jack for AC adapter 


$19.95 


tiplication, division, percentage: with constant on 
all functions. wath full floating decimal point 


e Power source s 6 AAA cells 9 V DC 
e Wallet is 2 tone texon cabinet is black plastic 


DIGITAL ALARM 
CLOCK 


$17.95 


NOT A KIT 


JE700 cLock 


The JE700 is a low cost digital clock, but 


$99.95 


$24.95 
KA-2401 | 


в a very high quality unit. The unit fea- 
tures a simulated walnut case with di- 


mensions of 6" x 212” x 1 


. It utilizes a 


МАМ72 high brightness readout, and the 


12 or 24 Hour. 


115 VAC 


This large 


MM5314 clock chip 


$17.95 


igit clock (.6” 
minutes, .3” seconds) features the 
MM5314 clock chip. It operates 
from 117 МАС, and will operate in 
either a 12 or 24 hour mode. The 
clock is complete with a walnul 
grain case, and has fast set, slow 
set, and hold time set features, 


hours & 


KIT - ALL COMPONENTS & CASE $34.95 
WIRED & ASSEMBLED $39.95 


The Logic Probe is а uni winch is tor the most part 
indespensible in trouble shooting logic families. 
TTL. DTL RTL CMOS t derives the power it 
needs to operate directly ott of the circuit under 
tesi drawing a Scant 10 mA тах It uses а MANS 
feadnul to indicate any of the номид states by 
| these symbols {Н} 1 LOW! - o (PULSE) -Р The 

Prahe can delecl high frequency pulses to 45 MHz 
||: сап! ne used at MOS levels or circuit damege 
wall result 


M Д 
Р 4 ) 


—— pom 


$9.95 Per Kit 


printed circuit board 


T?L 5V 1A Supply 


This is a standard TTL power supply using the well known 
LM309K regulator IC to provide a solid 1 AMP of currentat 5 
volis We try tà make Ihings easy for you by providing 
everything you need in ane package. mcluding the hardware 


for only 


Completely Assembled 
Regulated Output 
Regulated Input 
Unregulated Output 


Limited 
Supply 


$9.95 Per Kit 


A World’s Smallest Microcomputer 
System? 


The manufacturer of this card, the Model 
710A, claims that this F8 computer card is 
"the world's smallest complete 8 bit micro- 
computer." The card comes fully assembled 
and tested and measures 4.5 by 6.5 inches 


SILI SOLYD 


short summary of the additions, which 


Updates to the 9900 Line 


Texas Instruments has announced addi- 
tions to the TMS9900 microcomputer prod- 
uct family in a release dated July 20, A 


(11.4cm by 15.2cm) with a standard 
double sided 22 pin edge connector. The 
term "complete" has the following seman- 
tics according to the Pronetics Corp press 
release: 


ө F8 Microprocessor with 2 us instruc- 
tion time. 

e 1 byte programmable memory. 

е 1K bytes programmable memory. , 

e 32 bidirectional latched single bit IO 


ports. 

* 2 independent external interrupt 
inputs. 

ө 2 independent programmable interval 
timers. 


€ Flexible terminal interface. 
* Physical size fits standard card cage 
products. 


At $159, completely assembled апа 
tested, the F8 Model 710A looks like a fair 
fulfillment of the adjective "complete." 
Individuals looking for a dedicated firmware 
controller, a starting point for an F8 general 
purpose system, or a computer for use in 
educational or laboratory programs should 
find this board to be a useful option. The 
manufacturer is Pronetics Corp, 6431 
Preston Crest, Dallas TX 75230, (214) 
270-8626. 


an off-beat gift. 


BYTE Posters 
PO Box 274 


603-924-7217 


Name 


Address 


OBill Master Charge 
Мо. 


 “ееееегееееееетееегезегесгесеуе 


140 


Jaffrey Center NH 03454 


should show up in personal computing end 
products in the next half year or so, is as 
follows: 


% TMS9980: This is а new MOS version 
of the TMS9900, packaged as a stan- 
dard 40 pin dual in line package with a 
physical description similar to most 8 
bit microprocessors: 8 bit data bus, 16 
bit address bus, etc. But there is a 
difference. If readers will recall Robert 
Baker’s article on the TMS9900 chip 
in the Apri! 1976 BYTE, the internal 
architecture of a 9900 is that of a 16 
bit minicomputer with hardware 
multiply and divide, 16 general pur- 
pose register like work areas, etc. The 
same instruction set is executed by the 
9980 with a slight drop in speed of 
execution due to the fact that byte 
addressing is now done in the external 
world with an 8 bit wide memory and 
peripherals data path instead of a 16 
bit data path. This product is to be 
sampled late in 1976, and we expect at 
least one manufacturer to put this on 
an Altair compatible plug in board for 
the personal computing market. The 
hardware of the 9980 features an 
onchip oscillator and clock generator, 
so the breadboarding and production 
of hardware with this chip should 
prove convenient. 


€ TMS9904 is a 4 phase clock generator 
and driver for use with the TMS9900 
computer circuit, using a crystal con- 
trolled input. 

© TMS9901 is a programmable systems 


— и 
"Bi аш 
7 298 $. ч ) 6 


... to snap up bicentennial memorabilia before you have 
to hunt through the nostalgia shops and pay 100 times 
the original price—if you're lucky enough to find a 
bargain—for an item as anachronistic and otherwise 
remarkable as Robert Tinney's Computing 1776 picture. | 


А same-size (16 by 20 inches, 41 by 51 ст) reproduc- 
tion of Tinney's original oil painting, this poster makes 


Don't wait for the nostalgia shops to get the last of these 
posters; get yours now for only $2.95. (Do you know 
what your old Amazing Science Fiction magazines and 
Superman comics that Mom threw out are worth now?) 


“еге еооеегееееееееоеееееесееегеггвгавееевеезвегсе 4 


Allow 6 - 8 weeks for processing. | 
| 
— Posters $2.95 each | 


City State . р 
O Bill! BankAmericard 


D Check Enclosed 
$. 


Exp. Date 


S. D. SALES Со. Р.О. BOX 28810-8 • DALLAS, TEXAS 75228 
4K LOW POWER RAM BOARD KIT 


THE WHOLE WORKS 


Imsai and Altair 8080 plug in compatible. Uses low power static 
21L02—1 500 ns. RAM's, which are included. Fully buffered 


drastically reduced power consumption, on board regulated, all 
sockets and parts included. Premium quality plated thru PC Board. ш 


8 Digit LED $1,000,000 CALCULATOR PURCHASE! 
“METRIC MASTER” We bought the entire stock of a major manufacturer. New, guaranteed units. 


$19 95 Five functions PLUS complete Metric Conversion functions. Re- 

chargeable batteries. Small, hand held size. With AC charger. 

“RAPID MAN — 12” 12 Digit - Desk Top Style. Sturdy design. With memory and four 
$29 95 complete functions. Big, bright display. 


ALARM CLOCK KIT SIX DIGIT LED 
Thousands of hobbyists have bought and built our original clock 
kit and were completely satisfied. But we have received many 


60 HZ CRYSTAL TIME BASE — 


GITAL CLOCKS $ 5 95 
s B. ALES EXCLUSIVE! a 


requests for an alarm clock kit with the same value and quality | KIT FEATURES: 
that you have come to expect from 5. D. So, here it is! A. 60 hz output with accuracy comparable to a digital watch 
THE KIT INCLUDES: B. Directly interfaces with all MOS Clock chips 
1 Mostek 50252 Alarm Clock Chip C. Super low power consumption (1.5 Ma typ.) 
6 Hewlett Packard .30 in. common cathode readouts D. Uses latest MOS 17 stage divider IC 
15 NPN Driver Transistors E. Eliminates forever the problem of AC line glitches 
2 Switches for time set F. Perfect for cars, boats, campers, or even for portable clocks 
2 Slide Switches for alarm set and enable at ham field days. BUY TWO FOR $10.00! 
1 Filter Cap $9 9 5 G. Small size, can be used in existing enclosures. 
4 ІМ4002 Rectifiers . KIT INCLUDES CRYSTAL, DIVIDER ic, PC BOARD PLUS ALL 
1 1М914 Diode OTHER NECESSARY PARTS AND SPEC 
l 101 Disc Cap 
esistors 
1 Speaker for alarm РСВ — $3.00 | ооо 19c MU INTEG RATED. CIRCUITS 74153 75c 
insi МА — — — — 
1 LED lamp for PM indicator XFMR~ $1.50 | 7402—18 7432 —34c 740-280 74184 — 106 
74L04 — 29c 7437 — 39c 7483 — 95c 74157 — 75c 
MOTOROLA RTL IC'S 74504 — 44c 7438 — 39c 7485 — 95c 74161 - 95c 
Brand new, factory prime. Hard to find, but still used in a variety 7404 — 19c 7440 — 19c 7586 — 45c 74164 — 1.10 
of projects. (See the RTL Cookbook by Howard W. Sams.) 7406 — 29c 7447 — 85c 7490 — 65c 74165 — 1.10 
MC724P — 59c MC780P — 89C MC791P — 69c 7408 — 19c 7448 — 85c 7492 — 75c 74174 -— 95c 
7410 — 19c 7451 — 19c 7495 — 75c 74181 — 2.50 
7411 — 29c 7453 — 19c 7496 — 89с 74191 — 1.25 
7413 — 50c 7473 — 39c 74121 — 38c 74192 — 1.25 
MC9709P — 69c 7420 — 19c 7474 — 35c 74123 — 65c 74193 - 1.00 
MC775P — 89c MC790P — 89c MC9760P — 69c 7575 — 35c 74141 — 75с 74195 —  69c 


1000 MFD FILTER CAPS 


Rated 35 WVDC. Upright style 
with P. C. leads. Most popular 
value for hobbyists. Compare 


at up to $1.19 each from fran- 
chise type electronic parts stores. 


S.D. SPECIAL 4 for $1. 


af ae 
CUBO" -piGITAL ALARM CLOCK CUBE 
A PERFECT GIFT — NOT A KIT! 
The CUBO Alarm Clock mfg. by Corvus, division of 
MOSTEK CORP. Originally sold for $49.95. We bought 
out their entire inventory. АП new, individually gift 
boxed. Mini size (2⁄2 сире) with maxi performance. 
T 


A. 4 Digit H.P ES: $14.95 

. igit H.P. Bright Display . 

В. ‘Second Hand" LED Activity Indicator ACH Our DEP IG H ASSORTMENT 

C. 24 Hour Alarm; 12 hour real time format Add 75c P.&H.) ture and standard sizes, single and 

D. 10 Minute Snooze сын. multi-position units. | Atl new > 
E. Auto Dispiay Dimming — Adjusts to Ambient Light first quality name brand a 
F. AM/PM Indicator Try one package and you'll re- 

G. Power Failure Indicator order more 

Uses Famous Mostek MK50250 MOS LSI IC : SPECIAL — 12/$1. 


WESTERN DIGITAL UART 
No. TR1602B. 40 pin DIP. 
This is a very powerful and popular part. 


NEW — $6.95 with data 
LIMITED QUANTITY 


MICROPROCESSORS & THINGS 
By AMD 

8080A Better than Intel $24.00 

8008-1 High Speed 8008 12.50 

8212 1/0 Port 3.50 

8224 Clock Generator 4.95 

2513 Character Generator 10.00 


UP YOUR COMPUTER! 
211.02—1 1K uon. POWER 500 NS | STATIC RAM 
S OF THE ESSE 
And so is power. Not only ме our RAM's faster t than a speeding bullet but they 
are now very low power. We are pleased to offer prime new 21L02 — 1 low power 
and super fast RAM's, Allows you to STRETCH your power supply farther and at 
the same time keep the wait light off. 8 FOR $17.50 


SALE ON CUT LEAD SEMICONDUCTORS C&K MINI TOGGLE SWITCH 
Leads were cut for PCB insertion. кр very | Мо. 7103 SUB MINI SPOT Center OFF. 
useable new, unuse ome House no. _ 
1М914/1п4148....,......... 0 SPECIAL — 99с 

1 TERMS: 


N4002 1Ampi00PIV......... 
Money Back Guarantee. No COD. Texas 


MOTOROLA POWER DARLINGTON 

Back in Stock! : 
Like MJ3001. NPN 80V. 10A. HFE 
6000 TYP. TO—3 case. We include a free 
723 C volt reg. with schematic for power 
supply. SPECIAL — $1.99 


FAIRCHILD BIG LED READOUTS 
A big .50 inch easy to read character. Now 
available in either common anode or com- 
mon cathode. Take your pick. Super low 
current drain, only 5 MA per segment typ- 
ical. YOUR CHOICE: 6 for $7.50 
ЕМО —510 Соттоп Anode $1.50 ea. 
FND —503 Common Cathode $1.50 ea. 


RESISTOR ASSORTMENT ua 
1/4 W 5% and 10%, PC leads. ч 
А good mix of values. 200/$2. 


745200 
256 Bit High Speed RAM 
Same as 82516 


$3.95 


1K PROM BACK IN STOCK! 
825129. 256Х4. Bipolar, 50 NS. 
FAST. WITH SPECS. 


$3.95 


8T97B 
Hex Tri-State Buffer. Back in stock. 


$1.25 


CALL YOUR BANK AMERICARD OR 
MASTER CHARGE ORDER IN ON OUR 
CONTINENTAL UNITED STATES TOLL 


FREE WATTS: 4_800—527-3460 
Texas Residents Call Collect 


214/271-0022 


S. D. SALES 
Р. О. Box 28810-B 
Dallas, Texas 75228 


1N4745A 16V 1W Zener 
EN2222 NPN Transistor 

EN2907 PNP Transistor . . Residents add 5% tax. Add 5% of order for 
243304 BEN Driver XU М 25/%1. | Postage and handling. Orders under $10. 
C103Y SCR. 800MA 6ОУ........ . | add 75c. Foreign orders: US Funds ONLY! 


ORDERS OVER $15. CHOOSE $1. FREE MERCHANDISE 


interface for the  TMS9900 ог 
TMS9980, which interfaces directly to 
the processor’s CRU port for interrupt 
priority, IO control and interval 
timing. It provides 15 individually 
maskable interrupt request lines or up 
to 16 programmable 10 ports, and can 
be programmed as an interval timer 
with resolution from 21 ps to 699 ms. 
TMS9902 is the 9900 family’s version 
of a UART. This circuit is customized 
to the ТІ CRU (Communications 
Register Unit) IO addressing scheme, 
and features data rates from 5 to 
76,800 bits per second, character 
lengths from 5 to 8 bits, and 1, 1.5 or 
2 stop bits per character with or 
without parity. 


€ TMS9903 is the synchronous com- 
munications port for the 9980 and 
9900 computers. This is similar to 
what is sometimes called a “USART” 
and features a wide variety of options. 
It will handle most synchronous data 
transmission protocols, including the 
BiSync and IBM's new Synchronous 
Data Link Control discipline, at data 
rates from DC to 250,000 bits per 
second. 


Samples have not yet been delivered on 
these items, and pricing is to be announced 
when samples are available. Inquiries from 
OEMs should be directed to Texas Instru- 
ments Inc, POB 5012, MS/84, Dallas TX 
75222, attention “9900 Family”. = 


Would You Like to Find Out About 
Hardware for Diagnosing and Testing 
Microprocessor Designs? 


Hewlett-Packard makes a broad line of 
test equipment intended for industrial and 
commercial design and maintenance applica- 
tions. A new applications note, AN 167-13, 
is now available, written by Bruce G Farly of 
Hewlett-Packard's Colorado Springs facility, 
describing some of the uses and applications 
of sophisticated testing equipment such as 
logic state analyzers and data generators. 
This 6 page applications note, entitled "The 
Role of Logic State Analyzers in Microproc- 
essor Based Designs" is available for the 
asking by writing to: Inquiries Manager, 
Hewlett-Packard Co, 1501 Page Mill Rd, 
Palo Alto CA 94304.5 


A New Graphics Option for OSI 


Shown off at the Personal Computing 76 
show in Atlantic City was the interface 
which produces these pictures. The manu- 
facturer of the "Super Video Board" which 
generates 128 by 128 raster graphics is Ohio 
Scientific Instruments, 11679 Hayden St, 
Hiram OH 44234. This board, which plugs 
into the OSI Model 400 system, can be used, 
as in photo 1, to draw pictures with low to 
moderate resolution, and to display the 
output of a software "logic state analyzer" 
program, as in photo 2. 


Photo 2. 


BYTE T-shirts 


Photo 1. 
If you can't afford to give that special person in your life a new 


e 
Ihe Perfect Gift: 
© 
microcomputer, consider the BYTE T-shirt. A gift in exquisite taste, 


= Р that says you really care, that suggests, ever so subtly, that NEXT 
BE - Christmas, when things are a little better, you might give him or her 
а new microcomputer, 


Or—dare to be selfish! Buy yourself a BYTE T-shirt. Available in 
blue heather with blue trim and red letters, or in white with blue 
trim and red letters, Only $5, including postage and handling. 


In unusual cases, processing may exceed 30 days. 
The Bytique 
PO Box 274 
Jaffrey Center NH 03454 
Please send me ——extra large - blue heather 
—— white with blue trim and 
red letters 
T-shirts @ $5 each (includes 
postage and handling) 


— large 
——medium 
——small 


Total enclosed $. 

Bil! MasterCharge No. 
Bill BankAmericard No. 
Name. 

Address — —————————— M 
City. CCS tate | . . . Zip 

Signature. 


Exp. Date. 
Exp. Date. 


Other colors, styles I'd like to see 
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UNIVERSAL POWER SUPPLY 


A unique plug-in supply by Panasonic, Usefui 
for calculators, small radios, charging many & 
various smal! NiCad batteries, Adjustment 
screw plug on the side changes output voltage 
to 4%, 6, 7%, or 9 volts DC at 100 MA, Output 
cord with plug, 6 ft long, 


No. SP-143C $4.50 3/$12 


POWER SUPPLY 
LAMBDA 5VDC 74 AMP 


LV-EE-5-OV $125.00 


NJE 5/OUP-D5 
5 VDC 32 AMP 


CLOCK KIT $14.00 
Includes all parts with MM5316 chip, 
etched & drilled PC board, transformer, 
everything except case. 
SP-284 $14.00 each 2/$25.00 


MEMORY SYSTEM $125.00 


New memory system by Honeywell, 


a mini-computer. Limited supply on hand. 


Ship мді 3 Ibs. #5Р-79 


3 Power supplies, transistorized & regulated. 
Made by TRANSISTOR DEVICES 

15 volts ОС Багр$................ $25.00 
30 volts ОС 2атр$................ 
15 volts DC 4.5 amps .............. 


small 

measures only 9x4x1 inches. 1024 core memory, 
1024 words with 8,9,10 bits/word. Random access, 
with all logic, register, timing, control, core select and 
sense functions in one package. New, booklet of 
schematics and data. Looks like a good beginning for 


269556862 


PARITY DETECTOR 


New packaged, made for RCA, detects even or odd parity, baud rate 110, 150 or 
134.46. Built-in logic supply for the IC's, operates from standard 115 vac. Control 
panel allows manual or automatic reset mode of operation. Aluminum enclosure (not 
shown), covers the electronics. TTY compatible, 

Ship wgt. 10 Ibs. $16.50 


COMPUTER DISPLAY TUBE 


New Sylvania 9 inch CRT, 85 degree deflection, with tinted faceplate, Same as used 
in Viatron systems (buy a spare). With complete specs. 
Ship wgt. 5 16$. $15.00 


LINEAR by RCA, brand new, gold bond process 


747 ; MM5314 
748 x MM5316 
1458 7001 
3401 

555 timer 


$3.00 
3.00 
8.00 


COMPUTER GRADE LOGIC SUPPLY CAPS, BRAND NEW 


47,000 Uf 25V $2.00 ST 1,000 50 .90 AL 
32,000 25 1.75 ST 3,300 35 1.25 AL 
160,000 10 2.00 ST 1,600 20 .60 AL 
66,000 10 2.00 ST 8,000 16 1.25 AL 
1,000 60 .90 AL 500 6 .35 AL 
2,000 55 1.00 AL “ST” screwtop....”AL” axial 


Please add shipping cost on above. 


PHONE 617—595-2275 FREE CATALOG SP-8 NOW READY 


MESHNA PO Bx 62 E. Lynn Mass. 01904 


BUTE 


reader 


Е А104 Computer Store (NY) 105 A 90 Logical Services 105 
SE ГӘ | се А140 Computer Talk 97 A 18 Meshna 143 
A138 Computer Warehouse Store 93 A145 MFE 71 
A 6 Continental Specialties 25 А 71 МРІ 39 
А 87 Creative Computing 98 A133 Micro Software Spec. 105 
A 70 American Microprocessors 97 A 41 Cromemco 1 A119 Midwestern Scientific Inst. 55 
A142 Associated Electronics 95 A 97 Data Domain 65 A 57 Mikos 69 
A107 Audio Design Electronics 105 A 7 Delta 137 A112 МіпіТеғт 18, 19 
А111 Вгїдаг 131 А 78 Digital Group 11 * MITS CIV, 4,5 
BYTE's Books 96, 130, 136 A 79 Economy Co. 75 A 62 Morrow 127 
BY'TE's Posters 140 A 47 Electronic Control Tech 101 A132 M&R Enterprises 60, 61 
BYTE's T-Shirts 142 A102 Eitron 135 A 22 National Multiplex 93 
A126 Cheap, Inc. 105 A135 Erickson 101 A146 NCR 67 
A127 Comptek 101 A 9 Godbout 119 A 40 Ohio Scientific Inst. 17 
A143 Computer Enterprises 105 ы HAL Communications 103 A147 OK Tool 91 
A 83 Computer Mart of NY 97 a IMS 8, 30, 31 64 Oliver Audio Eng. 97 
A141 Computer Room 95 A 15 James 133, 138, 139 63 Parasitic 59, 127 
A 76 Computer Store 97 A130 JGM Development Labs 101 85 Рег Com Data 69 
A103 Computer Store (CT) 101 A139 Kentucky Fried Computers 75 23 Polymorphic Systems 63, 71 


To get further information on the products advertised in BYTE, fill out the reader 
service card with your name and address. Then circle the appropriate numbers for the 
advertisers you select from this list, Add a 9 cent stamp to the card, then drop it in the 
mail. Not only do you gain information, but our advertisers are encouraged to use the 
marketplace provided by BY TE. This helps us bring you a bigger BYTE. 


24 Processor Tech 72, 73, 74 
Scelbi 15 

* Scientific Research 103 
27 SD Sales 141 

59 Solid State Sales 128, 129 
29 Southwest Tech. Cll 

30 Sphere CIII 


Reader Service (?) 


Subscribers, please bear with us. If you have not received a response to a 


BYTE reader service inquiry, the delay rests squarely upon us, not the Nas ide 
advertisers. We have quite frankly been inundated with requests since putting A 96  Synchro-Sound 41 
reader service on reply cards, and recently got a bit behind in processing. A 82 Technical Design Labs 13 
Each card must be keypunched and run through a (somewhat traditional) А136 Technical Systems Con. 67 | 
data processing operation currently implemented on an 1BM/360 Model 25 a % Mak Ege og Plastics 99 

» " " . ‚ тп Te 
with 16 К bytes of memory, 2311 disk drives апа an archaic tape operating A137 Vector Graphics 99 


system. As this note is written (September 10) the current reader service 
requests total 24,000 individual cards with multiple requests per card, and are 
being mailed to advertisers as mailing label printouts.m 


* Reader service inquiries not solicited. 
Correspond directly with company. 


Feedback is what keeps a linear amplifier in line. Like a linear amplifier, BYTE can use a bit 
of feedback. The BOMB analysis is done once a month to provide encouragement to authors 
and some formal feedback on how readers appreciate articles. BYTE pays the winning author a 
$50 bonus, so you can encourage the authors you like by voting your preferences. Remember 
that with few exceptions BYTE authors are just readers who have sat down at their typewriters 
to tell a story about what they've done or what they know about some aspect of this 
technology. 


BOMB: BOMB Bonus to Burt 


BYTE's Ongoing Monitor Box 
The winner of the August BOMB survey 


LIKED and a $50 bonus was Burt Hashizume, who 
PAGE ARTICLE LEAST BEST wrote “Microprocessor Update: Zilog 780.” 
6 Rosner: It's More Fun Than Crayons 012345678910 cdi for фы iu id Digital ae 
Pudor. Is APL? атала TSAA TV readout device, and Terry Steeden who 
26 Nelson: Beer Budget Graphics intarraca 012345678910 wrote “What’s an 121. (1 squared Ha 
32 Buschbach: Add This Graphics Display . . 012345678910 Remember that your preferences count 
40 Burhans: A Tip for Using Wiring Pencils 012345678910 in the BOMB evaluation. It is a way of giving 
42 Deres: An Enterprising Display Device 012345678910 direct feedback to authors about the content 
56 Rampil: Some Graphics Background . . . 012345678910 of their articles, and it gives us a real world 
78 Ciarcia: A Real Eye Opener 012345678910 basis for judgment of which articles to push 
106 Anderson: Video Display Terminal 012345678910 into print the fastest, M 
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SPHERE OFFERS: 
A Programmable Microprocessor 
Controller! 


5194: 


The Sphere TPU/1 micro computer on а 
card designed for use in control enviroments; 
whether it be personal, Business, Idustrial , or 
Engineering. TPU is an expandable CPU on a 
4.4x4.9 inch edge connector board. With 
the Motorola 6800 microprocessor a 6820 
parallel interface 256 or 512 bytes of EPROM 
2048 bits of static RAM , and a crystal con - 
trolled clock driver. Available on the 72 pin 
edge connector are all the necessary signals 
to interface the TPU/1 to almost any device. 
You can program the read only memory with 
special instructions to meet your needs, or 
buy our programmed ROM'S. 

Build or design your own computer 
configuration. The static memory is 


expandable to 32k and you can control tele- 
type or other I/O devices. Options include 
keyboard and 16 x 32 character CRT display 
module. 

The TPU allows ease of interfacing to vir- 
tually any device which needs to be intelli- 
gently monitored or controlled. Whether 
need a personal computer to handle your 
household budget or to use in your next elec- 
tronics project, this is the low cost unit 
which will do the job for you. 

This is not a toy! It was designed for use 
in OE M applications. It is a reliable and 
productive device controller. The pack- 
age is complete with assembled and 

tested TPU/1 schematics,manuals; 


all for the low price of $194 prepaid. 


» SPHERE 


CORPORATION 


940 North 400 East 
North Salt Lake, Utah 84054 


(801) 292-8466 


Order yours today and use the 
phere TPU/1 in your next elec- 
ronics project. | wanf 
vanity. Enclose ВАС,МС or | 
heck. Allow up to 30 days for 
lelivery. 


Measuring just 11" wide x 11" deep x 5” high, and weighing a 
mere 7 pounds, the Altair ™ 680b is a complete, general-purpose 
computer. 

The secret to this revolutionary; small computer is its CPU 
board. This double-sided board fits along the bottom of the Altair 
case and plugs directly into the front panel board. It contains 
the new 6800 microprocessor, 1,024 bytes of RAM memory, a 256 
byte PROM monitor, provisions for 768 bytes of additional PROM 
or ROM, and a single Interface port with a Motorola ACIA serial 
interface adapter which can be configured either RS-232 or TTY. 
A five level Baudot interface option is also available. 

The Altair-680b can be programmed from front panel switches, 
or it can be interfaced to a video display terminal, or teletype- 
writer. Three additional circuit boards can be plugged inside the 
Altair 680b for further memory and interface expansion. The first 
of these boards is a 16K static RAM memory board. 

Software already developed includes Altair 680 BASIC with 
all the features of the 8K BASIC previously developed for the 
Altair 8800. These include Boolean operators, the ability to read 
or write a byte from апу I/O port or memory location, multiple 
statements per line, and the ability to interrupt program execution 
and then continue after the examination of variable values. This 
software takes only 6.8K bytes of memory space and a copy is 
included free with the purchase of the Altair 680 16K memory 
board. 

Other software includes a resident two pass assembler. The 
Altair 680b is also compatible with Motorola 6800 software. 


The Altair 680b is ideal for hobbyists who want a powerful 
computer system at an economic price. Altair 680b owners qualify 


NOTE: Altair is a trademark of MITS, Inc. 


d 


for membership in the Altair Users Group, and like other Altair 
owners, they receive a complimentary subscription to Computer 
Notes and complete factory support. 


f % 
UA c a 


PRICES: 
Altair 680b kit with complete, easy-to-understand assembly man- 
ual, operator's manual, and programming manual...... ..... ..... $466 
Assembled Altair 6806Ы............ sss eene $625 
Altair 680b Turnkey model kit.. 395 
Expander Card 680MB (required to 'expand 680)... салы ООД 
Altair 680BSM 16K static RAM board kit with 680 BASIC... 5685 
Altair 680 BASIC when purchased ерагате!у........._........ 225200 
Вапаогорвбойе; d sso ceo озык зайырлы даланы ані те ДБ .$ 42 
MAIL THIS COUPON TODAY 
"m т eee ee ч 
П Enclosed is a check for 5. І 
O BankAmericard # or Master Charge # і 
[1 Altair 680b О Kit D Assembled D Other (specify) | 
enclose $8 for postage and handling ` | 
| D Please send free information package. | 
| МАМЕ | 
| ADDRESS І 
| CITY, — STATE & ZIP. i 
| eS = 
| Ў une | 
І 2450 Alamo SE/Albuquerque, ММ 87106, 505-243-7821 | 
D me eee eee .- .- .-. .-- .-- --- аьа ee -- -l 


Price, specifications subject to change. Please allow up to 60 days for delivery. 


